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PHP 是 全 球 最 普及 、 应 用 最 广泛 的 互联 网 开发 语言 之 一 ， 它 有 开放 的 源 代码 ， 独 特 的 语法 结构 ， 
包含 了 C、Java、Perl 等 语言 的 特点 ， 有 具有 多 种 数据 库 的 支持 ， 并 且 支 持 跨 平台 的 操作 ， 支 持 面向 对 象 
的 编程 ， 而 且 是 完全 免费 的 。PHP 越 来 越 受 到 广大 程序 员 的 青睐 和 认同 ， 正 在 逐渐 成 为 程序 开发 者 使 
用 的 主流 语言 。 

为 了 帮助 众多 学 习 PHP 的 读者 提高 PHP 项 目 开发 水 平 ， 笔 者 精心 编著 了 本 书 。 本 书 充分 利用 了 
PHP 在 应 用 程序 的 设计 和 开发 上 具有 灵活 高 效 的 特点 ， 以 10 个 实用 的 网 络 程序 为 案例 ,详细 地 讲解 了 
整个 项 目的 开发 过 程 。 


本 书 内 容 


本 书 共 10 章 。 第 1、2、3、4、6、7、8 章 结合 目前 最 常用 的 MySQL 5.0 数据 库 分 别 开 发 了 九 九 
度 供求 信息 网 、BCTY365 网 上 社区 系统 、 办 公 自 动 化 管理 系统 、 电 子 商务 平台 、 物 流 配送 信息 网 、 学 
校 图 书馆 管理 系统 和 博客 管理 系统 ; 第 5 章 应 用 目前 最 流行 的 Ajax 技术 结合 最 常用 的 SQL Server 2000 
数据 库 开 发 了 在 线 考试 网 ， 从 而 实现 了 一 个 无 刷新 的 在 线 考试 系统 ; 第 9 章 结 合 最 新 的 Access 2003 数 
据 库 开发 了 企业 快 信和 网 ， 其 中 应 用 Web Service 服务 实现 短信 的 发 送 ， 应 用 imap 电子 邮件 系统 函数 实 
现 了 邮件 的 收发 :， 第 10 章 结 合 目 前 流行 的 ADODB 类 库 开发 了 支持 不 同 数据 库 的 Online 影视 365 网 ， 
可 以 根据 用 户 的 需求 更 换 不 同类 型 的 数据 库 。 


本 书 特点 


合 视频 讲解 

对 于 初学 者 来 说 ， 视 频 讲解 是 最 好 的 导师 ， 它 能 够 引导 初学 者 快速 地 入 门 ， 使 初学 者 感受 到 编程 
的 快乐 和 成 就 感 ， 进 一 步 增强 学 习 的 信心 。 鉴 于 此 ， 本 书 为 每 一 个 案例 都 配备 了 视频 讲解 ， 初 学 者 可 
以 通过 视频 讲解 实现 案例 中 的 功能 。 

上 代码 贴 十 

案例 类 书籍 通常 会 包含 大 量 的 程序 代码 ， 宛 长 的 代码 往往 令 初 学 者 望 而 生 且 。 为 了 方便 读者 阅读 
和 理解 代码 ， 本 书 避 免 了 连续 大 篇 幅 的 代码 ， 将 其 分 割 为 多 个 部 分 ， 并 对 重要 的 变量 、 方 法 和 知识 点 
设计 了 特色 的 代码 贴 士 。 

总 知识 扩展 

为 了 增加 读者 的 编程 经 验 和 技巧 ， 书 中 每 个 案例 都 标记 有 注意 、 技 巧 等 提示 信息 ， 并 且 在 每 章 内 
容 中 都 提供 一 项 专题 技术 。 
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适合 读者 


本 书 定位 于 想 要 使 用 PHP 进行 网 站 开发 的 初中 级 读者 ， 一 些 案例 对 于 高 级 用 户 也 具有 很 好 的 参考 
价值 。 同 时 ， 本 书 也 特别 适合 作为 大 专 院 校 计 算 机 专业 广大 师 生 的 案例 参考 书 。 对 于 初学 者 来 说 不 必 
担心 书 中 的 案例 做 不 出 来 ， 因 为 本 书 附带 光盘 中 的 视频 录像 会 引导 您 去 做 ， 再 结合 书 中 的 知识 讲解 ， 
相信 初学 者 不 但 会 做 案例 程序 ， 而 且 能 够 根据 理解 自行 设计 类 似 的 程序 。 


本 书 约定 


由 于 篇 幅 有 限 ， 本 书 每 章 并 不 能 逐一 介绍 案例 中 的 各 模块 。 作 者 选择 了 其 中 基础 和 典型 的 模块 进 
行 介 绍 ， 对 于 功能 重复 的 模块 ， 由 于 技术 、 设 计 思 路 和 实现 过 程 基本 相同 ， 因 此 没有 在 书 中 体现 。 
本 书 中 涉及 的 功能 模块 在 光盘 中 都 附带 有 视频 录像 ， 方 便 读者 学 习 。 


致 读者 


本 书 由 PHP 软件 开发 团队 策划 并 组 织 编写 ， 主 要 编写 人 员 有 张 仿 彦 、 刘 中 华 、 杨 丽 、 张 景 坤 、 吕 
继 迪 、 刘 欣 、 王 苦 、 孙 秀 梅 、 刘 玲玲 、 梁 晓 岚 、 顾 彦 玲 、 黄 锐 、 孙 明 娇 、 寇 长 梅 、 张 鹏 斌 、 董 大 永 、 
张 艳 、 郭 佳 博 、 乔 敏 、 梁 水 、 王 永生 、 陈 丹 丹 、 吕 双 、 徐 薇 、 陈 紫红 、 唐 政 、 房 大 伟 、 张 领 、 苗 春 义 、 
马 文 强 、 王 殊 宇 、 李 言 、 李 贺 、 刘 锐 宁 、 周 桓 、 张 金辉 等 。 在 编写 本 书 的 过 程 中 ， 我 们 以 科学 、 严 说 
的 态度 ， 力 求 精益 求 精 ， 但 错误 、 玻 漏 之 处 在 所 难免 ， 敬 请 广大 读者 批评 指正 。 我 们 的 服务 邮箱 是 
tmoonbook@sina.com，th_press@263.net， 读 者 在 阅读 本 书 时 ， 如 果 发 现 错误 或 遇 到 问题 ， 可 以 发 送 电 
子 邮件 及 时 与 我 们 联系 ， 我 们 会 尽快 给 予 答复 。 

如 今 ， 在 计算 机 图 书 领 域 有 许多 案例 型 的 图 书 在 吸引 读者 ， 感 谢 您 购买 本 书 ， 希 望 本 书 能 成 为 您 
的 良师益友 ， 成 为 您 步 入 编程 高 手 之 路 的 踏 脚 石 。 

宝剑 锋 从 磨 研 出 ， 梅 花香 自 苦 寒 来 。 祝 读书 快乐 ! 
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九 九 度 供求 信息 网 


( Apache+PHP+phpMyAdmin+MySQL 5.0 实现 ) 


在 金 球 知 识 经 济 和 信息 化 高 速 发 展 的 今天 ， 信 息 化 是 决定 企业 成 败 的 关键 因 
素 , 企业 需要 在 网 站 上 发 布 供求 信息 ,以 促使 企业 在 同 领 域 中 得 到 突飞猛进 的 发 展 。 
一 个 广泛 的 、 快 速 的 、 自 由 的 信息 交流 平台 ， 为 用 户 带 来 方便 的 同时 ， 也 会 给 
企业 带 来 无 限 的 商机 。 于 是 ， 以 因 将 网 为 基础 的 信息 交流 平台 即 九 九 度 供求 信息 网 
出 现 了 。 九 九 度 供 求 信息 网 致力 于 优化 信息 交流 ， 实 现 信息 的 快速 交流 。 通 过 阅读 
本 章 ， 可 以 学 习 到 : 
使 当前 窗口 承载 框架 页 中 的 起 链接 页 面 
如 何 自动 计算 以 系 统 日 期 为 基数 的 相对 日 期 
do…While 循环 语句 的 应 用 
查询 关键 字 描 红 技 术 
在 Windows 操作 系统 下 搭建 PHP 开发 环境 
在 Windows 操作 系统 下 创建 数据 库 和 数据 表 
PowerDesigner 建 模 的 应 用 
单元 测试 技术 
框架 技术 在 Web 网 站 中 的 应 用 
如 何 发 布 网 站 
表单 数据 的 两 种 提交 方式 
应 用 phpMyAdmin 工具 创建 和 删除 数据 库 、 数 据 表 


于 于 于 于 于 于 于 于 于 于 于 至 
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1.1 开发 青 景 


X xX XxX 信息 科技 有 限 公 司 是 一 家 以 整合 渠道 资源 为 主 的 高 科技 公司 。 为 了 扩大 企业 规模 ， 增 强 企 
业 的 竞争 力 , 该 公司 决定 向 多 元 化 发 展 , 借助 Internet 在 国内 的 快速 发 展 , 聚集 部 分 资金 投入 网 站 建设 ， 
为 企业 和 用 户 提供 综合 信息 服务 ， 以 向 企业 提供 有 偿 信息 服务 为 乔 利 方式 ， 打 造 一 个 全 新 的 供求 信息 
网 。 例 如 ， 提 供 企业 广告 、 发 布 各 类 免费 供求 信息 、 发 布 企业 付费 信息 等 服务 方式 。 现 需要 委托 其 他 
单位 开发 一 个 综合 信息 网 站 。 


1.2 ”系统 分 析 


1.2.1 需求 分 析 


对 于 信息 网 站 来 说 ， 用 户 的 访问 量 是 至 关 重 要 的 。 如 果 网 站 的 访问 量 很 低 ， 那 么 就 很 少 有 企业 会 
要 求 为 他 提供 有 偿 服务 ， 也 就 没有 利润 可 言 了 。 因 此 信息 网 站 必须 为 用 户 提供 大 量 的 、 免 费 的 、 有 价 
值 的 信息 才能 够 吸引 用 户 。 为 此 ， 网 站 不 仅 要 为 企业 提供 各 种 有 偿 服 务 ， 还 需要 额外 为 用 户 提 供 大 量 
的 无 偿 服 务 。 通 过 与 企业 的 实际 接触 和 沟通 ， 确 定 网 站 应 包括 招聘 信息 、 求 职 信息 、 培 训 信 息 、 公 寓 
信息 、 家 教 信息 、 和 车 辆 信息 、 物 品 求购 、 物 品 出 售 、 求 兑 出 竞 ， 寻 求 合 作 、 企 业 广 告 等 服务 。 

通过 实际 调查 ， 要 求 供求 信息 网 具有 以 下 功能 : 
界面 设计 美观 大 方 、 方 便 、 快 捷 、 操 作 灵 活 ， 树 立 企业 形象 。 
实现 强大 的 供求 信息 查询 ， 支 持 模糊 查询 。 
用 户 不 需要 注册 ， 便 可 免费 发 布 供求 信息 。 
免费 发 布 的 供求 信息 必须 经 后 台 审 核 后 才能 正式 发 布 ， 避 免 不 良 信息 。 
支持 海量 数据 录入 。 
由 于 供求 信息 数据 量 大 ， 后 台 应 该 可 以 随时 清理 数据 。 


办 办 办 办 多 办 


1.2.2 ”可行 性 分 析 


根据 《GB8567 一 88 计算 机 软件 产品 开发 文件 编制 指南 》 中 可 行 性 分 析 的 要 求 ， 制 定 可 行 性 研究 报 
告 如 下 : 


1. 引言 

(1) 编写 目的 

为 了 给 企业 的 决策 层 提供 是 否 进 行 项 目 实施 的 参考 依据 ， 现 以 文件 的 形式 分 析 项 目的 风险 、 项 目 
需要 的 投资 与 效益 。 

(2) 背景 


XX XxX 信 息 科技 有 限 公司 是 一 家 以 整合 渠道 资源 为 主 的 高 科技 公司 。 企 业 为 了 不 断 满足 客户 的 需 
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求 ， 为 达到 企业 在 同行 业 领 域 中 的 领先 地 位 ， 现 需要 委托 其 他 公司 开发 一 个 综合 信息 网 ， 项 目 名 称 为 
九 九 度 供求 信息 网 。 

2. 可 行 性 研究 的 前 提 

(1) 要 求 

九 九 度 供求 信息 网 要 求 能 够 提供 信息 搜索 、 信 息 定位 描 红 、 发 布 免费 信息 、 发 布 付费 信息 、 发 布 
企业 广告 、 对 各 类 发 布 的 信息 进行 审核 、 删 除 、 检 索 等 功能 。 

(2) 目标 

九 九 度 供求 信息 网 的 主要 目标 是 提供 强大 的 搜索 功能 ， 准 确 的 信息 描 红 定位 功能 ， 付 费 信 息 的 管 
理 、 免 费 信 息 的 审核 和 删除 功能 。 

(3) 条 件 、 假 定 和 限制 

项 目 需要 在 两 个 月 内 交付 用 户 使 用 。 系 统 分 析 师 需要 3 天 内 到 位 ， 用 户 需要 4 天 时 间 确 认 需 求 分 
析 文 档 。 去 除 员工 两 个 月 的 正常 休息 日 16 天 ， 那 么 程序 开发 人 员 需 要 在 1 个 月 零 儿 天 的 时 间 内 进行 系 
统 设计 、 程 序 编码 、 系 统 测试 、 程 序 调试 和 网 站 部 署 工作 。 

(4) 评价 尺度 

根据 用 户 的 要 求 ， 系 统 应 以 搜索 引擎 为 主 ， 对 于 发 布 的 供求 信息 应 能 及 时 准确 地 保存 、 审 核 、 查 
询 、 描 红 定位 。 由 于 用 户 存在 多 个 营业 点 ， 系 统 应 具有 局 域 网 操作 的 能 力 ， 在 多 个 营业 点 同时 运行 系 
统 时 ， 系 统 中 各 项 操作 的 延 时 不 能 超过 10 秒 钟 。 此 外 ， 在 系统 出 现 故 障 时 ， 应 能 及 时 进行 恢复 。 

3. 投资 及 效益 分 析 

(1) 支出 

根据 系统 的 规模 及 两 个 月 的 项 目 开 发 周期 ， 公 司 决定 投入 5 个 人 。 因 此 ， 公 司 将 直接 支付 8 万 元 
的 工资 及 各 种 福利 待遇 。 在 项 目 安装 及 调试 阶段 ， 用 户 培训 、 员 工 出 差 等 费用 支出 需要 2 万 元 。 在 项 
目 维护 阶段 预计 需要 投入 2 万 元 的 资金 ， 累 计 项 目 投入 需要 12 万 元 资金 。 

(2) 收益 

用 户 提供 项 目 资金 30 万 元 。 对 于 项 目 运行 后 进行 的 改动 ,采取 协商 的 原则 根据 改动 规模 额外 提供 
资金 。 因 此 从 投资 与 收益 的 效益 比 上 ， 公 司 可 以 获得 18 万 元 的 利润 。 

项 目 完成 后 ， 将 给 公司 提供 资源 储备 ， 包 括 技术 、 经 验 的 积累 ， 以 后 再 开发 类 似 的 项 目 时 ， 可 以 
极 大 地 缩短 项 目 开 发 周期 。 

4. 结论 

根据 上 面 的 分 析 ， 技 术 上 不 会 存在 问题 ， 因 此 项 目 延期 的 可 能 性 很 小 。 在 效益 上 ， 公 司 投入 5 个 
人 、 两 个 月 的 时 间 获 利 18 万 元 ， 比 较 可 观 。 在 公司 今后 的 发 展 上 可 以 储备 网 站 开发 的 经 验 和 资源 ， 因 
此 认为 该 项 目 可 以 开发 。 


1.2.3 ”编写 项 目 计划 书 


根据 《GB8567 一 88 计算 机 软件 产品 开发 文件 编制 指南 》 中 的 项 目 开发 计划 要 求 ， 结 合 单位 实际 情 


况 ， 设 计 项 目 计 划 书 如 下 : 
。3。 多 
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1. 引言 

(1) 编写 目的 

为 了 保证 项 目 开 发 人 员 按时 保质 地 完成 预订 目标 ， 更 好 地 了 解 项 目 实际 情况 ， 按 照 合理 的 顺序 开 
展 工作 ， 现 以 书面 的 形式 将 项 目 开发 生命 周期 中 的 项 目 任务 范围 、 项 目 团队 组 织 结构 、 团 队 成 员 的 工 
作 责 任 、 团 队 内 外 沟通 协作 方式 、 开 发 进度 、 检 查 项 目 工作 等 内 容 描述 出 来 ， 作 为 项 目 相关 人 员 之 间 
的 共识 和 约定 以 及 项 目 生 命 周期 内 的 所 有 项 目 活动 的 行动 基础 。 

(2) 背景 

九 九 度 供求 信息 网 是 本 公司 与 X X X 信 息 科技 有 限 公司 签 定 的 待 开发 项 目 ， 网 站 性 质 为 信息 服务 
类 型 ， 可 为 信息 发 布 者 有 偿 或 无 偿 提 供 招 聘 、 求 职 、 培 训 、 求 购 、 公 寓 、 车 辆 、 房 屋 和 出 售 等 信息 。 
项 目 周期 为 两 个 月 ， 项 目 背景 规划 如 表 1.1 所 示 。 


表 1.1 项 目 背景 规划 
项 目 名 称 签 定 项 目 单位 项 目 负 责 人 项 目 承 担 部 门 
四 方 ，X Xx 信息 科技 有 限 公司 设计 部 站 
九 九 度 供求 信息 网 开发 部 门 


2. 概述 

(1) 项 目 目标 

项 目 目 标 应 当 符合 SMART 原则 ， 把 项 目 要 完成 的 工作 用 清晰 的 语言 描述 出 来 。 九 九 度 供求 信息 
网 的 项 目 目标 如 下 


九 九 度 供求 信息 网 主要 用 来 为 用 户 提供 信息 服务 ， 对 于 生活 和 工作 中 的 各 类 信息 都 应 尽 可 能 地 全 
部 包括 在 内 ， 例 如 人 公寓、 求职、 招聘 、 培 训 、 招 商 、 房 屋 、 和 车辆、 出售、 求购 等 信息 。 项 目 发 布 后 ， 
要 实现 能 够 为 用 户 生活 、 工 作 带 来 极 大 的 方便 并 提高 企业 知名 度 、 为 企业 产品 宣传 节约 大 量 成 本 的 目 
标 。 整 个 项 目 需要 在 两 个 月 的 期 限 结束 后 ， 交 给 客户 进行 验收 。 
(2) 产品 目标 与 范围 
一 方面 九 九 度 供求 信息 网 能 够 为 企业 节省 大 量 人 力 资源 , 企业 不 再 需要 大 量 的 业务 人 员 去 跑 市 场 ， 
间接 为 企业 节约 了 成 本 。 另 一 方面 ， 九 九 度 供求 信息 网 能 够 收集 海量 供求 信息 ， 将 会 有 大 量 用 户 访 问 
网 站 ， 有 助 于 提高 企业 知名 度 。 
(3) 应 交付 成 果 
项 目 开发 完成 后 ， 交 付 的 内 容 如 下 : 
加 ”以 光盘 的 形式 交付 九 九 度 供求 信息 网 的 源 程 序 、 网 站 数据 库 文件 、 系 统 使 用 说 明 书 。 
回 客户 方 应 用 自己 的 服务 器 ， 因 此 需要 乙方 架设 Apache 服务 器 、 安 装 PHP 开发 环境 、 协 助 甲 
方 购买 域名 ， 将 开发 的 九 九 度 供求 信息 网 发 布 到 互联 网 上 运行 。 
回 ”网 站 发 布 到 互联 网 上 以 后 ， 进 行 后 期 的 6 个 月 无 偿 维护 与 服务 ， 超 过 6 个 月 后 进行 网 站 有 偿 
维护 与 服务 。 
(4) 项 目 验 收 方式 与 依据 
项 目 验收 分 为 内 部 验收 和 外 部 验收 两 种 方式 。 在 项 目 开 发 完成 后 ， 首 先进 行内 部 验收 ， 由 系统 测 
4。 


第 1 章 九 九 度 供求 信息 网 (Apache+PHP+phpMyAdmin+MySQL 5.0 实现 ) 


试 员 根据 用 户 需 求 和 项 目 目标 进行 验收 。 项 目 在 通过 内 部 验收 后 交 给 用 户 进行 验收 ， 验 收 的 主要 依据 
为 需求 规格 说 明 书 。 

3. 项 目 团队 组 织 

(1) 组 织 结构 

为 了 完成 九 九 度 供求 信息 网 的 项 目 开发 ， 公 司 组 建 了 一 个 临时 的 项 目 团队 ， 由 项 目 经 理 、 系 统 分 
析 师 、PHP 开发 工程 师 、 网 页 设计 师 和 系统 测试 员 构 成 ， 如 图 1.1 所 示 。 


项 目 经 理 


系统 分 析 师 PIE 开 发 工程 师 网 页 设计 师 系统 测试 员 
图 1.1 项 目 团队 组 织 结构 图 
(2) 人 员 分 工 
为 了 明确 项 目 团队 中 每 个 人 的 任务 分 工 ， 现 制定 人 员 分 工 表 ， 如 表 1.2 所 示 。 
表 1.2 人 员 分 工 表 
技术 水 平 工作 描述 

负责 项 目的 审批 、 决 策 的 实施 、 项 目的 前 期 
MBA 分 析 、 策 划 、 项 目 开发 进度 的 跟踪 、 项 目 质 
量 的 检查 
高 级 系统 分 析 师 项 目 开发 部 | 系统 分 析 师 负责 系统 功能 分 析 、 系 统 框架 设计 
高 级 PHP 工 程 师 PHP 开 发 工程 师 | 负责 软件 前 后 台 设 计 与 编码 


高 级 美工 设计 师 负责 网 页 风格 的 确定 、 网 页 图 片 的 设计 
高 级 系统 测试 工程 师 | 项 目 开发 部 “| 系统 测试 员 对 软件 进行 测试 、 编 写 软件 测试 文档 


1.3 系统 设计 


1.3.1 系统 目标 


根据 需求 分 析 的 描述 以 及 与 用 户 的 沟通 ， 现 制定 网 站 实现 目标 如 下 : 


< 
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系统 采用 人 机 对 话 方式 ， 界 面 美观 友好 ， 界 面 简洁 、 框 架 清晰 、 美 观 大 方 。 
灵活 快速 地 填写 供求 信息 ， 使 信息 传递 更 快捷 。 

信息 查询 灵活 、 方 便 ， 数 据 存储 安全 可 靠 。 

实施 强大 的 后 台 审 核 功能 。 

实现 强大 的 搜索 引擎 ， 支 持 模糊 查询 、 关 键 字 描 红 功 能 等 。 

对 用 户 输入 的 数据 ， 系 统 进行 严格 的 数据 检验 ， 尽 可 能 排除 人 为 的 错误 。 

网 站 最 大 限度 地 实现 易 维护 性 和 易 操作 性 。 

为 充分 展现 网 站 的 交互 性 ， 供 求 信息 网 采用 动态 网 页 技术 实现 用 户 信息 在 线 发 布 。 
具备 完善 的 后 台 管理 功能 ， 能 够 及 时 、 准 确 地 对 网 站 进行 维护 和 更 新 。 


1.3.2 系统 功能 结构 


因 办 办 办 办 办 办 


九 九 度 供求 信息 网 前 台 功 能 结构 图 如 图 1.2 所 示 。 


图 1.2 九 九 度 供求 信息 网 前 台 功 能 结构 图 
九 九 度 供求 信息 网 后 台 功 能 结构 图 如 图 1.3 所 示 。 


9》 CD 
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图 1.3 九 九 度 供求 信息 网 后 台 功 能 结构 图 
\ 6. 
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1.3.3 系统 流程 图 


九 九 度 供求 信息 网 的 系统 流程 如 图 1.4 所 示 。 


oF 


发 布 付 费 供 求 信 息 


发 布 企业 广告 信息 


图 1.4 系统 流程 图 


1.3.4 系统 预览 


九 九 度 供求 信息 网 由 多 个 程序 页 面 组 成 。 下 面 列 出 几 个 典型 页 面 ， 其 他 页 面 参 见 光盘 中 的 源 程序 。 
前 台 首页 如 图 1.5 所 示 ， 该 页 面 用 于 实现 各 类 信息 的 查询 、 企 业 广 告 信息 显示 、 后 台 登 录入 口 等 功 
能 。 搜 索引 擎 页 面 如 图 1.6 所 示 ， 该 页 面 用 于 实现 各 类 信息 的 快速 检索 、 查 询 关键 字 描 红 等 功能 。 
发 布 免费 信息 页 面 如 图 1.7 所 示 ， 该 页 面 用 于 实现 发 布 分 类 的 免费 信息 功能 。 付 费 管理 页 面 如 
图 1.8 所 示 ， 该 页 面 用 于 实现 付费 信息 分 类 查看 、 付 费 信 息 审 核 、 付 费 信息 删除 等 功能 。 
。7。 多 
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图 1.7 发 布 免费 信息 (光盘 \TM\01\99pursey\release.php) 图 1.8 付费 管理 (光盘 \TM\01\99pursey\admin\find_fufei.php) 


免费 管理 页 面 如 图 1.9 所 示 , 该 页 面 用 于 实现 免费 信息 分 类 查看 、 免 费 信息 审核 、 免 费 信息 删除 等 
功能 。 管理 员 登 录 页 面 如 图 1.10 所 示 , 该 页 面 用 于 实现 对 管理 员 登 录 的 用 户 名 和 密码 进行 验证 等 功能 。 


en 


图 1.9 免费 管理 (光盘 \TM\01\99pursey\admin\finddd.php》 图 1.10 管理 员 登 录 ( 光 盘 \TM\01\99pursey\admin\login.php) 


8. 
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1.3.5 开发 环境 


在 开发 九 九 度 供求 信息 网 时 ， 该 项 目 使 用 的 软件 开发 环境 如 下 : 
.服务 器 端 

操作 系统 ，Windows 2003 Server/Linux (推荐 ) 。 
服务 器 : Apache 2.2。 

PHP 软件 : PHP 5.1.6。 

数据 库 : MySQL 5.0.24。 

MySQL 图 形 化 管理 软件 : phpMyAdmin-2.9.0.2。 
开发 工具 : Dreamweaver 8。 

浏览 器 : IE 6.0 及 以 上 版 本 。 

分 辨 率 : 最 佳 效 果 1024X 768 像素 。 

客户 端 

浏览 器 : IE 6.0 及 以 上 版 本 。 

分 辨 率 : 最 佳 效 果 1024X768 像素 。 


国 图 回国 国 图 轿 罗 一 


国 : 罗 总 


1.3.6 文件 夹 组 织 结构 


在 编写 代码 之 前 ， 可 以 把 系统 中 可 能 用 到 的 文件 夹 先 创 建 出 来 〈 例 如 ， 创 建 一 个 名 为 admin 的 文 
件 夹 ， 用 于 保存 网 站 的 后 台 文 件 ) ， 这 样 不 但 可 以 方便 以 后 的 开发 工作 ， 也 可 以 规范 网 站 的 整体 架构 。 
笔者 在 开发 九 九 度 供求 信息 网 时 ， 设 计 了 如 图 1.11 所 示 的 文件 夹 架构 图 。 在 开发 时 ， 只 需要 将 所 创建 
的 文件 保存 在 相应 的 文件 夹 中 即 可 。 


日 加 Pusey 

日 上 ain 一 一 一 一 一 一 一 一 一 用 于 存储 网 站 后 台 文件 

由 国 inages 一 一 一 一 一 一 一 一 一 用 于 存储 网 站 后 台 使 用 的 图 片 资源 
自 em 一 一 一 一 一 一 一 一 一 用 于 存 人 数据 库 这 接 文件 
同一 一 一 一 一 一 一 一 一 一 用 于 存 情 网 站 使 用 的 C35 样式 表 
同一 一 一 一 一 一 一 一 一 一 用 于 存 铺 让 据 库 文 件 
同 Inases 一 一 一 一 一 一 一 一 一 一 用 于 存储 网 站 前 台 使 用 的 图 片 资源 
名 下 用 于 存储 网 站 使 用 的 自 定义 函数 


图 1.11 文件 夹 组 织 结构 


1.4 在 Windows 操作 系统 下 搭建 PHP 开发 环境 


PHP 能 否 高 效 、 稳 定 地 运行 依赖 于 服务 器 的 编译 和 执行 ， 本 节 主 要 介绍 如 何在 微软 的 Windows 操 
作 系 统 中 架设 安全 、 可 靠 的 PHP 运行 环境 。 
9。 多 
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1.4.1 在 Windows 下 应 用 AppServ 快速 配置 PHP 开发 环境 


AppServ 是 PHP 网 页 架 站 工具 组 合 包 , 可 以 将 网 络 上 免费 的 架 站 资源 重新 包装 成 单一 的 安装 程序 。 
它 提供 了 简易 、 快 速 的 PHP 运行 环境 的 搭建 机 制 ， 读 者 只 需 按 照 普通 应 用 软件 的 安装 方式 就 可 以 完成 
Apache+MySQL+PHP+phpMyAdmin 的 安装 与 配置 工作 。 

下 面 以 AppServ-win32-2.5.7 为 例 来 介绍 AppServ 的 安装 和 使 用 方法 。 

安装 AppServ 之 前 应 从 官方 网 站 http://www.appservnetwork.com 下 载 最 新 版 本 的 AppServ-win32- 
2.5.7.exe 安装 程序 。 


旬 和 视频 录像 : TMNOINIX\ 在 Windows 下 应 用 AppServ 快速 配置 PHP 开发 环境 .swf 


在 Windows 下 应 用 AppServ 快速 配置 PHP 开发 环境 的 操作 步骤 如 下 : 
(1) 双击 A -2.5.7.exe 文件 ， 打 开 如 图 1.12 所 示 的 AppServ 启动 窗口 。 
[zl 


Welcome to the AppServ 25.7 
Setup Wizard 


ad wa ude you throuh the netalation of ppsery 


recommended that you cdose all other applcations 
eee Seon fe ete peels hind 


Whthout having to reboot 
me 


Chck Next to continue, 


SOMPUTER 一 


理 


图 1.12 ”AppServ 启动 窗口 


(2) 单 击 图 1.12 中 的 Next 按钮 ， 打 开 如 图 1.13 所 示 的 AppServ 安装 协议 窗口 。 


License Agreement 
Please review the icense terms before instaling App5erv 2.5.7. 


(GNU LESSER GENERAL PUBLIC LICENSE 
Version 2.1, February 1999 


Copyriht (C) 1991, 1999 Froo Softmen 


Jf you accept the terms of the agreement, cick 1 Agree to continue, You must accept the 
agreement to install AppServ 2.5.7. 


Nullsoft Insal System Y2.19 


ee ge ee 


图 1.13 ”AppServ 安装 协议 窗口 
\ »。10* 
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(3) 单 击 图 1.13 中 的 IAgree 按钮 打开 如 图 1.14 所 示 的 窗口 ， 在 该 窗口 中 可 以 设置 AppServ 的 安 
装 路 径 〔 默 认 安装 路 径 一 般 为 C:\AppServ) 。AppServ 安装 完成 后 ，Apache、MySQL、PHP 都 将 以 子 
目录 的 形式 存储 到 该 目录 下 。 


上 Appserv 2.5.7 Setup 


Choose Install Location 
Choose the folder in which to install Appserv 2.5.7, 


Setup wil nstal AppSery 2.5.7 n the folowing folder, To nstal n a different Folder, cick 
Browse and select another Folder, Clck Next 


图 1.14 AppServ 安装 路 径 选 择 


(4) 单 击 图 1.14 中 的 Next 按钮 打开 如 图 1.15 所 示 的 窗口 ， 在 该 窗口 中 可 以 选择 要 安装 的 程序 和 
组 件 〈 默 认为 全 选 状态 ) 。 


区 AppServ 2.5.7 Setup 


Select Components 


Select the components you want to install, clear the components 
you do not want to instal 


Nullsoft Install System y2,19 


图 1.15 AppServ 安装 选项 
(5) 在 图 1.15 中 单 击 Next 按钮 ， 打 开 如 图 1.16 所 示 的 窗口 ， 该 窗口 主要 设置 Apache 的 端口 号 。 
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耳 百 后 | 


Apache HTTP Server Information 
Please enter your servers information. 


图 1.16 ”Apache 端口 号 设置 
(6) 单 击 图 1.16 中 的 Next 按钮 ， 打 开 如 图 1.17 所 示 的 窗口 。 该 窗口 主要 对 MySQL 数据 库 的 
root 用 户 的 登录 密码 及 字符 集 进行 设置 , 这 里 将 字符 集 设置 为 GB2312 Simplified Chinese, 表示 MySQL 
数据 库 的 字符 集 将 采用 简体 中 文 形式 。 
站 百 加 
AN MySQL Server Configuration 
Mu SQL Configure the My5QL Server instance, 
Please enter Root password for My5QL Server. 
Enter root password 


Cr 


| old Password Support (PHP MySQL API function,) 
厂 Enable InnoDB 


Nullsoft Install oysterm v2,18 


图 1.17 MySQL 设置 
(7) 单 击 图 1.17 中 的 Install 按钮 后 开始 安装 ， 如 图 1.18 所 示 。 


SS 
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1.18 AppServ 安装 窗口 
(8) 安装 完成 后 可 以 在 “开始 ”菜单 的 AppServ 相关 操作 列表 中 启动 Apache 及 MySQL 服务 ， 
如 图 1.19 所 示 。 


Completing the AppSery 2.5.7 Setup 
Wizard 


AppServ 2.5.7 has been instaled on your computer, 
Cick Finish to dose this wizard, 


WD Beart apachel 


W Start My5QL 


图 1.19 AppServ 安装 完成 窗口 


(9) 安装 好 AppServ 后 ， 整 个 目录 默认 安装 在 C:\AppServ， 此 目录 下 包含 4 个 子 目录 ， 如 图 1.20 
所 示 ， 用 户 可 以 将 所 有 网 页 文件 存放 到 www 目录 下 。 


司 
DD Mpache2.2 Apache 的 存储 目录 
问 My5Q&L 一 一 一 一 MySQ1 的 存储 目录 


站 | php5 一 一 一 一 一 RJP 的 存储 路 径 
癌 ww 一 网 页 文件 及 phplWyAdnin 的 存储 路 径 


图 1.20 AppServ 目录 结构 
(10) 打开 浏览 器 ,在 地 址 栏 中 输入 “http:Wlocalhost” 或 者 “http:/127.0.0.1”， 如 果 打开 如 图 1.21 


所 示 的 网 页 ， 则 说 明 AppServ 安装 成 功 。 
*。 13。 乡 
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HE 


EL 


Vs 


,ChangsLog 

README 

，AUTHOPS 

,COPYING 
MEMWwwwAppServNemwark 


奇 


The AppServ Open Project - 2.5.7 for Windows 


衣 phpMyAdmin Database Manager Version 2902 
2) PHP Intormation Version 5.1.5 


Appsev is a maryng cpen source sctware Instsler package tor Wndows incluces 
» Apache Web Server 
~ PHP ScriptLanguat 
。 MySQL Databese Versicn 5.0.246 
~ phpMyAdmin Darahase Manager Varscn2 90.2 


Change Language :E Ss 


» Easy way to build Webserver, Database Server with AppServ :-) 司 


[| ere 


图 1.21 AppServ 测试 页 


1.4.2 Windows 下 Apache 的 安装 配置 


Apache 是 全 世界 使 用 范围 最 广 的 Web 服务 软件 ， 超 过 50% 的 网 站 都 在 使 用 Apache 服务 器 ， 它 以 
高 效 、 稳 定 、 安 全 、 免 费 而 成 为 了 最 受 欢迎 的 服务 器 软件 。 

本 节 主 要 介绍 如 何在 Windows 操作 系统 中 安装 和 配置 Apache 服务 器 。 安 装 Apache 服务 器 前 ， 应 
到 官方 网 站 http://www.apache.org 下 载 Apache 的 安装 程序 。 
鳃 和 视频 录像 : TM\O1\Ix\Windows 下 Apache 的 安装 配置 .swf 


在 Windows 下 实现 Apache 的 安装 配置 的 操作 步骤 如 下 : 


(1) 下 载 Apache 的 安装 包 apache_2.0. 


所 示 的 Apache 的 安装 窗口 。 


倍 Apsche HTTP Server 2.0 — 


59-win32-x86-no_ssl.msi 后 ， 双 击 该 安装 包 ， 打 开 如 图 1.22 


Installation Vizard 
Welcome to the Installation Wizard for 
Apache HTTP Server 2.0.59 


The Installation Wizard wil install Apache HTTP Server 2.0.59 
on your computer. To continue, cick Next, 


WARNING: This program is protected by copyright law and 
international treaties. 


图 1.22 Apache 的 安装 窗口 
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(2) 在 图 1.22 中 单 击 Next 按钮 ， 打 开 如 图 1.23 所 示 的 Apache 许可 协议 窗口 ， 选 中 I accept the 


terms in the license agreement 单 选 按钮 。 


(3) 在 图 1.23 中 单 击 Next 按钮 ， 打 开 如 图 1.24 所 示 的 HTTP 服务 窗口 。 


六 Apache ITTP Server 2.0 ~ Iastallatisal 和 本 


License Agreement 
Please read the folowing icense agreement carefuly， 


Apache License 习 
Version 2.0, January 2004 
http:Jwww,.apache.orgiicenses/ 
|TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION 


1, Definitions, 


Instalshield — 


ee | 


图 1.23 许可 协议 窗口 


he MTTP Server 2.0 ~ Installation Yizere 到 


Read This First 
Read this Before Running Apache on Windows. 


Apache HTTP Server < 


[wnatis it? 
|The Apache HTTP Serveris a powerful and flexible HTTP/1.1 compliant web server. 
Originally designed as a replacement forthe NCSA HTTP Server, ithas grown to be 
lthe most popular web server on the Intemet As a project ofthe Apache Software 
Foundation, the developers aim to collaboratively develop and maintain a robust, 
commerciak- grade, standards-based server with freely available source code. 


[me Latest Version 


Details ofthe latestversion can be found on the Apache HTTP server project page 
lunder 
htpyml he or 


1.24 HTTP 服务 窗口 


(4) 在 图 1.24 中 单 击 Next 按钮 ， 打 开 如 图 1.25 所 示 的 输入 服务 器 信息 窗口 。 输 入 服务 器 的 相关 
信息 ， 如 网 络 域名 、 服 务 器 名 和 管理 员 邮 箱 等 ， 这 里 可 以 根据 用 户 的 实际 情况 输入 。 在 下 方 的 单 选 按 
钮 组 中 ， 如 果 选 择 第 一 项 则 可 以 对 任何 用 户 开放 Apache 服务 ， 同 时 设置 服务 器 的 侦 听 端口 为 80; 如 
果 选 择 第 二 项 则 只 有 本 地 用 户 可 以 连接 和 使 用 Apache 服务 。 


他 Apache MTTP Server 2.0 - Instsllation GE x| 


Server Information 
Please enter your server's information, 


”df 


Installshield 


人 for All Users, on Port 80, as a Service ~- Recommended, 
TFT rte rt EO SEED 


1.25 输入 服务 器 信息 窗口 


全 注意 : 如 果 选 择 的 是 第 一 项 , 又 同时 安装 了 IIS, 那 就 必须 修改 IIS 的 默认 端口 ,否则 将 导致 Apache 
无 法 正常 工作 。 更 改 IIS 的 默认 侦 听 端口 80， 可 以 在 1IS 的 管理 器 中 进行 设置 ， 或 者 停止 IIS 


的 服务 也 可 以 。 
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(5) 设置 完成 后 ， 单 击 图 1.25 中 的 Next 按钮 ， 打 开 如 图 1.26 所 示 的 选择 安装 方式 窗口 。 这 里 有 


两 种 选择 方式 : Typical 典型 安装 和 Custom 自 定义 安装 。 通 常 ， 用 户 都 选择 典型 安装 方式 ， 单 击 Next 
按钮 ， 打 开 如 图 1.27 所 示 的 安装 窗口 。 


Setup Type 
Choose the setup type that best sults your needs, 


Chek Change to install to a dfferent folder 3 


本 Install Apache HTIP Server 2.0 to the folder: 
ciprogram Flesypache Goupt 


rical program features wil be instaled. (Headers andUibraries 
For compling modules wil not be installed.) 


[co | 
图 1.26 选择 安装 方式 图 1.27 设置 安装 的 路 径 
(6) 在 如 图 1.27 所 示 的 设置 安装 的 路 径 窗口 中 可 以 选择 安装 的 路 径 ， 单 击 Change 按钮 ， 打 开 如 
图 1.28 所 示 的 对 话 框 来 修改 文件 的 安装 路 径 。 
(7) 在 如 图 1.28 所 示 的 窗口 中 ， 对 安装 的 路 径 进行 修改 ， 然 后 单 击 OK 按钮 ， 打 开 如 图 1.29 所 
示 的 准备 安装 窗口 。 
(8) 在 图 1.29 中 单 击 Install 按钮 ， 打 开 如 图 1.30 所 示 的 窗口 开始 安装 。 


个 apache MTTP Server 2.0 -~ Installation Wren 下 
Ready to Install the Program 
和 x 四 The wieard ready to begin instalation 
Change Current Destination Folder 
Browse to the destination foder, Chck Instal to begn the nstalation 
a fF you wank to review or change any of your installation settings, cck Back, Chck Cancel to 
2 ek the ward. 


Ek Apache Group 司 加 | 本 


图 1.28 修改 安装 的 路 径 图 1.29 准备 安装 


(9) 图 1.30 中 所 有 文件 复制 完成 后 ，Apache 安装 完成 ， 打 开 如 图 1.31 所 示 的 窗口 ， 单 击 Finish 
按钮 完成 Apache 安装 。 


Sr 
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Installing Apache HTTP Server 2.0.59 
The program features you selected are being instaled 
加 please wat whie the Installation Wizard instals Apache HTTP Server 
2.0,59. This may take several minutes. 


Installation Wizard Completed 


The Installation Wizard has successfuly installed Apache HTTP 
Server 2.0.59, Clck Finish to vdt the wizard. 


图 1.30 复制 文件 图 1.31 安装 完成 

(10) 接 下 来 ， 测 试 Apache 服务 是 否 安 装 成 功 。 选 择 “ 开 始 ”/“ 所 有 程序 ”命令 ， 在 弹出 的 菜 
单 中 能 够 看 到 Apache 服务 器 相关 操作 列表 ， 同 时 如 果 在 系统 托盘 中 有 一 个 辆 图 标 ， 则 表示 Apache 服 
务 已 经 启动 。 

(11) 单 击 短 图 标 后 ， 打 开 如 图 1.32 所 示 的 窗口 ， 在 该 窗口 中 ， 选 择 Stop 选项 表示 停止 Apache 
服务 器 ; 选择 Start 选项 表示 启动 Apache 服务 器 (Apache 服务 器 的 当前 状态 为 停止 时 ， 该 功能 可 用 ) ， 
选择 Restart 选项 表示 重新 启动 Apache 服务 器 。 双 击 种 图 标 后 ， 打 开 如 图 1.33 所 示 的 窗口 ， 可 以 进行 
启动 和 停止 服务 器 的 各 种 操作 。 


Service Status 
© 


启动 Apache 服务 器 


ip 
Bestart 


Seryices 


加 区 


htt 


Start 
Stop 


Restart 


Li 


= 中 [Apache/2.2.3 Win32) 
图 1.32 左 键 菜单 图 1.33 ”Apache 服务 器 的 监视 器 

(12) 在 浏览 器 中 输入 “http://localhost/” 或 者 输入 “http://127.0.0.1/”， 如 果 能 够 浏览 到 如 图 1.34 
所 示 的 窗口 ， 说 明 Apache 服务 器 安装 成 功 。 

(13) Apache 服务 器 安装 成 功 后 ， 接 下 来 对 Apache 服务 器 进行 配置 ， 以 便 Apache 服务 器 能 够 识 
别 PHP 文件 。 配 置 Apache 服务 器 主要 是 在 Apache 安装 目录 下 的 conf 子 目录 中 的 httpd.conf 文件 中 进 
行 的 ， 找 到 该 文件 并 用 记事 本 等 文本 编辑 器 打开 该 文件 。 

17* 乡 
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已 全 灾 壬 南 Mh。 车 可 9 在 这 人 昌 录 中 过 加 六 宇 ， 承 者 把 这 二 页 划 ]| 


这 不 是 你 想 看 见 的 页 面 吧 ? 


二 看 由 这 十 其 桓 。 友 加 为 网 站 香 末 天 实 了 这 十 地点 的 放置 。 妇 时 古本 问 ， 计 咨询 堆 扩 此 址 点 的 人 
化 和 全 有 阳江 全 的 并 去 者 直入 P 作 ,也 开 流 


加 cke 取 冯 已 生 上 人 在 此 妆 条 乒 中。 
各 可以 三江 甩 Apaehe 的 网站 服 务 枯 上 ， 自 由 地 使 用 下 而 的 卫 片 。 夺 世代 用 Apacke! 


i J 
厅 | i 


图 1.34 测试 Apache 服务 器 是 否 安装 成 功 
(14) 定位 到 DocumentRoot 一 行 , 可 以 将 该 路 径 修改 为 合适 的 路 径 , 例如 , 设置 为 DocumentRoot" 
Ci\Apache\Apache2\Wwebpage" 表 示 Apache 服务 器 的 虚拟 目录 为 C:\Apache\Apache2\webpage。 
(15) 将 光标 定位 到 DirectoryIndex index.html index.html.var， 在 其 后 面 添 加 一 个 PHP 默认 页 ， 通 
常 是 index.php， 表 示 当 访问 该 服务 器 时 如 果 未 指定 要 访问 的 PHP 文件 ， 则 默认 访问 index.php 文件 。 
更 改 后 的 代码 如 下 : 
DirectoryIndex index.html index.html.var index.php 
(16) 为 了 使 Apache 识别 PHP 的 扩展 名 ， 搜 索 并 定位 到 httpd.conf 文件 的 如 下 部 分 : 
<Directory "C:/Apache/Apache2/cgi-bin"> 
AllowOverride None 
Options None 
Order allow,deny 
Allow from all 
</Directory> 
在 后 面 添加 如 下 两 行 代码 : 
AddType application/x-httpd-php .php .phtml .php3 .php4 
AddType application/x-httpd-php-source .phps 
(17) 为 了 能 够 使 用 模块 功能 ， 模 块 通常 以 DSO 方式 构建 ， 读 者 需要 定位 到 如 下 代码 : 
#LoadModule ssl_ module modules/mod_ssl.so 
使 得 能 够 在 使 用 前 获得 指令 的 功能 ， 然 后 以 module 方式 加 载 PHP， 指 向 PHP 5.0 目录 下 的 
php5apache2.dll 文件 ， 添 加 如 下 代码 : 


LoadModule php5_module c:\phps\phpsapache2.dll 


1.4.3 Windows 下 MySQL 的 安装 配置 


PHP 能 够 支持 市 面 上 的 大 多 数 数据 库 ， 如 MySQL、Access、SQL Server、Oracle 等 ， 而 MySQL 
数据 库 是 PHP 程序 开发 人 员 公认 的 黄金 搭档 ， 这 不 仅 因为 MySQL 是 完全 网 络 化 的 跨 平台 关系 型 数据 


SS 
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库 系 统 ， 也 是 具有 客户 机 /服务 器 体系 结构 的 分 布 式 数据 库 管 理 系统 。 它 具有 功能 性 强 、 使 用 简洁 、 管 
理 方便 、 运 行 速度 快 、 版 本 升级 快 、 安 全 性 高 等 优点 ， 而 且 MySQL 数据 库 完 全 免费 ， 从 官方 网 站 
http://www.mysql.com 即 可 免费 下 载 到 最 新 版 本 的 MySQL 安装 包 。 


鳃 和 视频 录 像 : TMNOINX\Windows 下 MySQL 的 安装 配置 .swf 


在 Windows 下 实现 MySQL 的 安装 配置 的 操作 步骤 如 下 : 

(1) 如 果 下 载 的 是 Windows Essentials (x86) ， 例 如 mysql-4.1.11-essential-win.exe， 直 接 双击 该 
文件 安装 即 可 ， 安 装 完毕 后 ， 在 “开始 ”菜单 中 选择 “运行 ”命令 ， 在 弹出 的 对 话 框 中 输入 cmd， 进 
入 “命令 提示 符 ”， 输 入 mysqld-nt.exe， 即 可 启动 MySQL 服务 ; 如 果 还 想 详细 地 配置 MySQL， 则 需 
要 进入 Ci\mysql\bin 目录 ， 运 行 MySQLInstanceConfig.exe， 并 按 提示 操作 即 可 。 

(2) 如 果 下 载 的 是 Windows (x86) ， 例 如 mysql-essential-5.0.24-win32.msi， 解 压 该 文件 后 双击 
setup.exe 安装 程序 即 可 逐步 完成 MySQL 的 安装 。 

(3) 如 果 下 载 的 是 Without noinstall (unzip in C\) ， 直 接 将 该 文件 解压 到 指定 的 安装 目录 下 。 在 
“开始 ”菜单 中 选择 “运行 ”命令 ， 在 弹出 的 对 话 框 中 输入 cmd， 然 后 进入 “命令 提示 符 ”， 输 入 
mysqld-nt.exe 命令 ， 即 可 启动 MySQL 服务 器 。 


1.4.4 Windows 下 PHP 的 安装 配置 


架设 基于 PHP 的 Web 服务 器 , 安装 PHP 是 必须 的 。 由 于 PHP 的 代码 公开 , 所 以 其 升级 速度 较 快 。 
安装 PHP 之 前 应 从 官方 网 站 http:/www.php.net/ 下 载 最 新 版 本 的 PHP 安装 程序 ， 下 面 以 
php-5.1.4-Win32.zip 为 例 讲解 PHP 的 配置 方法 。 
风 4 视 频 录像 :TM\OI\NIxX\WWindows 下 PHP 的 安装 配置 .swf 
在 Windows 下 实现 PHP 的 安装 配置 的 操作 步骤 如 下 : 
(1) 成 功 下 载 到 PHP 的 安装 包 后 ， 首 先 应 对 其 进行 解压 ， 如 解压 到 Ci\php5 目录 下 ， 如 图 1.35 所 示 。 


[TD mu Es RN IAL Pm 
四- 
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图 1.35 ”PHP 解压 后 的 文件 


(2) 将 Ci\php5\ 目 录 下 的 所 有 .dll 文件 复制 到 C:\Windows\system32\〈 如 果 是 Windows 2000 操作 
系统 ， 则 为 C\WINNT\system32\) 目录 下 。 
(3) 将 C:phpS\ 目 录 下 的 php.ini-dist 文件 复制 到 C:\Windows\〔 如 果 是 Windows 2000 操作 系统 ， 
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则 为 C\WINNT\) 目录 下 ， 然 后 将 php.ini-dist 重 命名 为 php.ini， 并 用 记事 本 打开 该 文件 进行 编辑 ， 具 
体 编辑 方式 如 下 : 
首先 ， 定 位 到 该 文件 register_globals = Off 所 在 行 ， 将 Off 改 为 On。 代码 如 下 : 

register_globals = On 

其 次 ， 定 位 到 该 文件 extension_dir=".\" 所 在 行 ， 将 路 径 改 为 "Ci:\php5\ext"。 代 码 如 下 : 

extension_dir="C:\php$\ext" 

最 后 ， 查 找 定位 Windows Extensions， 将 下 面 两 行 代码 : 

; extension=php gd2.dll 

; extension=php_mysql.dll 
前 面 的 注释 〈 即 分 号 标识 符 ) 去 掉 ， 这 样 PHP 就 可 以 支持 GD2 函数 库 和 MySQL 相关 函数 ， 如 果 想 让 
PHP 支持 其 他 功能 函数 ， 同 样 需 要 将 与 这 些 操作 函数 相关 的 dll 文件 前 的 注释 去 掉 。 


外 注意 : 以 上 为 PHP 的 常规 配置 ， 在 PHP 的 官方 论坛 上 可 以 查 到 更 多 的 详细 配置 。 由 于 PHP 的 版 本 
有 多 种 ,所 以 php.ini 的 配置 也 存在 差别 ,具体 使 用 时 应 根据 实际 情况 配置 php.ini 文件 ,php.ini 
文件 的 配置 信息 在 2.5.2 节 有 详细 介绍 。 

(4) PHP 配置 完成 以 后 ， 需 要 重新 启动 Apache 服务 器 ， 然 后 编写 testphp 文件 并 输入 如 下 代码 : 


<?php 
phpinfo(); 
> 


将 文件 保存 到 Apache 安装 目录 下 的 webpage 子 目 录 下 ， 然 后 在 浏览 器 中 输入 
http://127.0.0.1/test.php， 如 果 显 示 如 图 1.36 所 示 的 页 面 则 说 明 PHP 配置 成 功 。 
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1.36 测试 成 功 
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技巧: 安装 文件 的 路 径 也 要 遵循 一 定 的 客观 原则 , 为 了 避免 在 Windows 和 Linux 间 移 植 程序 时 带 来 
的 不 便 ， 选 择 Di\usr\local\php 的 目录 时 要 和 在 Linux 下 的 安装 目录 相 匹配 。 建 议 最 好 不 要 选 
择 中 间 有 空格 的 目录 ， 如 E:\program Files\PHP， 这 样 做 会 导致 一 些 未 知 错 误 或 崩溃 发 生 。 


1.4.5 在 Windows 下 设置 IIS+PHP 的 执行 环境 


PHP 可 以 在 很 多 服务 器 下 运行 ， 下 面 介绍 IIS 的 安装 方法 以 及 PHP 是 如 何在 IIS 服务 器 下 运行 的 。 

1. llS 的 安装 

Interet 信息 服务 器 (Internet Information Server, 缩写 为 IS) 是 Microsoft 的 Web 服务 器 ， 它 集成 
于 WindowsNT Server 之 中 ， 方 便 易 用 ， 为 Web 应 用 程序 提供 了 功能 强大 的 运行 平台 。 

IIS 目前 最 新 版 本 为 6.0, 在 Windows 2003 Server 操 作 系统 中 默认 安装 ,如 果 没 有 安装 Windows 2003 
Server， 可 以 选择 IIS 5.0， 它 可 以 在 Windows XP 或 者 Windows 2000 操作 系统 中 安装 ， 对 于 开发 而 言 ， 
IIS 的 各 个 版 本 之 间 的 区 别 并 不 大 。 

(1) 在 Windows XP 或 者 Windows 2000 操作 系统 下 安装 IIS 
颁 4 视频 录 像 :TM\OI\x\ 在 Windows XP 或 者 Windows 2000 操作 系统 下 安装 IIS.swf 

选择 “开始 ”/“ 设 置 ”/“ 控 制 面 板 ” 命 令 ， 启 动 “添加 /删除 程序 ”应 用 程序 ， 单 击 “ 添 加 /删除 
Windows 组 件 ” 图 标 ， 在 弹出 的 “Windows 组 件 向 导 ” 对 话 框 的 “组 件 ” 列 表 框 中 选择 “Internet 信息 
服务 (IIS) ”选项 ， 最 后 单 击 “ 下 一 步 ” 按 钮 ， 即 可 完成 IIS 的 安装 。 

(2) 在 Windows 2003 Server 服务 器 下 安装 IIS 
鳃 4 视频 录像 : TM\01\Ix\ 在 Windows 2003 Server 服务 器 下 安装 IIS.swf 

首先 选择 “开始 ”/“ 控 制 面板 ”命令 ， 然 后 启动 “添加 /删除 程序 ”应 用 程序 ， 单 击 “ 添 加 /删除 
Windows 组 件 ” 图 标 ， 在 弹出 的 “Windows 组 件 向 导 ” 对 话 框 的 “组 件 ” 列 表 框 中 选择 “应 用 程序 服 
务 器 ”选项 ， 然 后 单 击 “详细 信息 ”按钮 ， 选 择 “Internet 信息 服务 (IIS) ”选项 ， 最 后 单 击 “ 下 一 步 
按钮 ， 即 可 完成 IIS 的 安装 。 

全 注意 : 若 想 在 IIS 中 支持 PHP 的 运行 环境 ， 在 安装 IIS 时 ， 需 在 “网 站 访问 权限 ”窗口 中 选中 读 取 、 
运行 脚本 (如 ASP) 、 执 行 (如 1SAPI 应 用 程序 或 CGI) 选项 。 

2. 架设 PHP 到 IIS 服务 器 

在 架设 PHP 到 IIS 服务 器 之 前 , 首先 应 确保 PHP 已 经 正确 安装 到 系统 中 。 本 节 将 以 Windows 2003 
Server 服务 器 中 的 TS 6.0 为 例 ， 介 绍 架设 PHP 到 IIS 服务 器 的 方法 。 

[区 视频 录像 : TM\01\Ix\ 在 Windows 下 设置 IS+PHP 的 执行 环境 .swf 


(1) 选择 “开始 ”/“ 管 理工 具 ”/“Internet 信息 服务 〈IIS) 管理 器 ”命令 ， 打 开 如 图 1.37 所 示 


的 Internet 信息 服务 窗口 。 
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司 文 件 (操作 (和 ) 查看 W) 窗口 w) 帮助 (HD |=l8lx 
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图 137 Internet 信息 服务 窗口 
(2) 右 击 “ 默 认 网 站 ”节点 ， 在 弹出 的 快捷 菜单 中 选择 “属性 ”命令 ， 将 打开 如 图 1.38 所 示 的 对 
话 框 。 


了 到 
目录 安全 性 | HTTP 头 1 自 定 义 模 误 | 
网 站 “| 性 能 ”| 。 ISAPI 第 选 器 主 上 录 “| 文档 
此 资源 的 内 容 来 自 : 


他 此 计算 机 上 的 目录 @) 
个 另 一 台 计 算 机 上 的 共享 G) 


个 重 定向 到 VERLQD 
本 地 路 径 €©); [Inetpub Weeroot 四 
人 脚本 资源 访问 中 应 记录 访问 四 
克 读 职 到 ) 瑟 索引 资源 G) 
厂 SAW 
厂 目录 浏览 @) 
应 用 程序 设置 
应 用 程序 名 加) 人 EGR 到 除 ) | 
开始 位 置 全 认 网 站 > 

配置 @)... 

执行 权限 @): 肢 二 和 可 执行 文件 = rei| 
应 用 程序 池 加: Defaul tAppPool 了 部 工人 L) | 


1.38 默认 Web 站 点 属性 


(3) 单 击 图 1.38 中 “ 主 目录 ”选项 卡 下 的 “配置 ”按钮 ， 打 开 如 图 1.39 所 示 的 对 话 框 。 
(4) 单 击 图 1.39 中 的 “添加 ”按钮 将 打开 如 图 1.40 所 示 的 对 话 框 ， 单 击 “ 可 执行 文件 ”文本 框 
后 的 “浏览 ”按钮 ， 在 打开 的 窗口 中 选择 php5 目录 下 的 php5isapi.dll 文件 ， 在 “扩展 名 ”文本 框 中 输 


a 
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入 “php”， 


映射 | 选项 | 调试 | 


本 ISAFI ji 


TS ‘system32\i a 
asp E WINDOWS\systen32\inetsrv\e 
edx C: MWINDOWS\system32\inetsrv\a. .. GET, HEA. 
cer C: \WINDOWS\system32\inetsrv\a. .. GET, 
ide C: \WINDOWS\system32\inetsrv\h GET, POST 
CMWTNNNWSY swst om32 Vinet srwde GFT, 


通配符 应 用 程序 映射 执行 顺序 ) ) ; 


插入 QD... 
编辑 (I) 
出 除 是 


Cm |] ww | Ww | 
图 1.39 应 用 程序 配置 
(5) 单 击 “ 主 目录 ”选项 卡 中 的 “浏览 ”按钮 ， 选 择 网 站 的 路 径 ， 如 图 1.41 所 示 。 


然后 单 击 “ 确 定 ” 按 钮 ， 实 现 扩展 名 的 映射 。 
到 


添加 /篇 辑 应 用 程序 扩展 名 映射 四 | 


扩展 名 到 ) php 


动作 
2 


个 限制 为 0); | 


怀 脚本 引擎 GE) 


万 确 文 件 是 在 WW  [_ 动 宝 | 取消 | 后 | 


图 1.40 添加 /编辑 应 用 程序 扩展 名 映射 


默认 网 站 尾 性 21x| 
目录 安全 性 ”| TP 头 自 定义 措 进 8 务 器 扩展 | 
网 站 | 性 能 |  ISAEI 第 过 器 [ 主 B 录 | 六 省 
此 资源 的 内 容 来 自 : 
6 此 计算 机 上 的 目录 四 ) 
个 另 一 台 计 算 机 上 的 共享 GE) 
个 重 定向 到 VRLQW) 
未 地 路 径 世 下 :AppServwwwwmrvOlvslvl1 训 览 O) | 
人 脚本 资源 访问 I) 厂 记录 访问 Q) 
民 读 职 @B) 怀 索引 资源 G) 
Vy SAW 
人 目录 浏览 @) 
应 用 程序 设置 
应 用 程序 名 吕 ) ; 展 愉 后 用 程序 删除 包 ) | 
开始 位 置 : 人 : 认 网 站 > 
执行 权限 到 ) : 脚本 和 可 执行 文件 er 
应 用 程序 池 @) ; DefaultAppPool 部 载 L) | 


Cm j] we | _ maw | ww | 
设置 网 站 的 路 径 
理 器 ”窗口 中 单 击 “Web 服务 扩展 ”节点 ， 在 “Web 服务 扩 


图 1.41 
(6) 在 “Internet 信息 服务 (IIS) 管 


ss 
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展 ” 区 域 中 选择 “所 有 未 知 ISAPI 扩展 ”选项 ， 然 后 单 击 “ 人 允许 ”按钮 ， 将 该 服务 的 状况 由 “禁止 ” 
设置 为 “允许 ”， 如 图 1.42 所 示 。 


十 Internet 信息 服务 (LIS) 管 理 器 


加 文件 四 换 作 外， 查看 WD 定 口 如 帮助 0 | =lelzl 


图 1.42 设置 Web 服务 扩展 


(7) 打开 HS 服务 器 ， 浏 览 index.php 文件 ， 如 果 在 浏览 器 中 打开 网 页 文件 ， 则 说 明 IIS+PHP 运 
行 环 境 配 置 成 功 ， 如 图 1.43 所 示 。 


1.43 IIS+PHP 运行 环境 配置 成 功 


1.5 ”数据库 设 计 


1.5.1 数据 库 分 析 


本 系统 是 一 个 中 小 型 的 供求 信息 平台 ， 但 是 由 于 平台 会 涉及 到 海量 数据 ， 因 此 需要 充分 考虑 到 成 本 
问题 及 用 于 需求 〈 如 跨 平台 ) 等 问题 ， 而 MySQL 是 世界 上 最 为 流行 的 开放 源码 的 数据 库 ， 是 完全 网 络 
\ “24 。 
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化 的 、 跨 平台 的 关系 型 数据 库 系统 ， 这 正好 满足 了 中 小 型 企业 的 需求 ， 所 以 本 系统 采用 MySQL 数据 库 。 
1.5.2 ”数据 库 概 念 设 计 


根据 前 面 对 系 统 所 做 的 需求 分 析 ， 系 统 设计 ， 规 划 出 本 系统 中 使 用 的 数据 库 实 体 分 别 为 免费 信息 
实体 、 付 费 信息 实体 、 广 告 信息 实体 、 管 理 员 实体 。 下 面 将 介绍 这 几 个 实体 的 E-R 图 。 
1. 免费 信息 实体 


免费 信息 实体 包括 编号 、 信 息 类 型 、 信 息 标 题 、 信 息 内 容 、 联 系 人 、 联 系 电 话 、 审 核 状 态 和 发 布 
时 间 属 性 。 其 中 审核 状态 属性 用 来 标识 信息 是 否 审核 ，“1” 表 示 “ 是 ”，“0” 表 示 “ 否 ”。 免 费 信 


息 实 体 的 E-R 图 如 图 1.44 所 示 。 
信息 标题 信息 内 容 


< 


发 布 时 间 审核 状态 


图 1.44 免费 信息 实体 E-R 图 
2. 付费 信息 实体 
付费 信息 实体 包括 编号 、 信 息 类 型 、 信 息 标题 、 信 息 内 容 、 联 系 人 、 联 系 电话 、 发 布 时 间 、 截 止 
时 间 和 审核 状态 属性 。 其 中 审核 状态 属性 用 来 标识 信息 是 否 付费 ,“1” 表 示 “ 是 ”,， “0” 表 示 “ 和 否 ”。 
付费 信息 实体 的 E-R 图 如 图 1.45 所 示 。 


信息 标题 信息 内 容 


图 1.45 付费 信息 实体 E-R 图 
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3. 广告 信息 实体 
“ 告 信 息 实体 包括 编号 、 信 息 标题 、 信 息 内 容 、 发 布 时 间 和 推荐 状态 属性 。 其 中 推荐 状态 属性 用 来 
标识 信息 是 否 在 前 台 显示 ，“1” 表 示 “ 是 ”，“0” 表 示 “ 否 ”。 广告 信息 实体 的 E-R 图 如 图 1.46 所 示 。 


图 1.46 广告 信息 实体 E-R 图 


管理 员 实 体 包括 编号 、 管 理 员 名 称 和 加 密 密 码 属性 。 管 理 员 实体 的 E-R 图 如 图 1.47 所 示 。 


加 密 密 码 


图 1.47 管理 员 实体 E-R 图 


1.5.3 ”使 用 PowerDesigner 建 模 


在 数据 库 概 念 设计 中 已 经 分 析 了 本 系统 中 主要 的 数据 实体 对 象 ， 通 过 这 些 实 体 可 以 得 出 数据 表 结 
构 的 基本 模型 ， 最 终 实 施 到 数据 库 中 ， 形 成 完整 的 数据 结构 。 下 面 将 介绍 使 用 PowerDesigner 工具 完成 
本 系统 的 数据 库 建 模 。 
(1) 运行 PowerDesigner， 并 在 PowerDesigner 主 窗口 中 选择 File/New 命令 ， 在 打开 的 New 对 话 
框 中 选择 Physical Data Model (物理 数据 模型 ,简称 PDM) 列表 项 ， 单 击 OK 按钮 ， 打 开 如 图 1.48 所 
示 的 Choose DBMS (选择 数据 库 管理 系统 ) 对 话 框 。 
Choose DDRS | 
DBMS: TEE -| | 
© Share: Use the shared DBMS definiion 
F Copy Create a copy of the DBMS definition in model 


EvstDiagam Jemvsicl niaeran 可 
于 三 EE 


图 1.48 Choose DBMS 对 话 框 
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(2) 在 DBMS 下 拉 列 表 框 中 选择 MySQL 数据 库 ， 这 里 选择 MySQL 3.23 版 本 ， 这 是 由 于 当前 使 
用 的 PowerDesigner 的 版 本 还 不 支持 MySQL 5.0， 但 是 随 着 PowerDesigner 版 本 的 升级 将 支持 更 多 的 
DBMS 。 

(3) 其 他 选项 采用 默认 设置 即 可 ， 单 击 OK 按钮 ， 打 开 新 建 的 PDM 窗口 。 在 该 窗口 的 上 方 为 空 
的 图 形 窗口 ， 下 方 为 输出 窗口 。 其 中 图 形 窗口 的 右 侧 有 一 个 工具 面板 ， 如 图 1.49 所 示 。 


图 1.49 工具 面板 


(4) 在 图 1.49 中 单 击 “ 建 立 表 ”图 标 ， 这 时 鼠标 指针 将 显示 为 斩 ， 在 图 形 窗口 的 合适 位 置 单 击 鼠 
标 左 键 ， 此 时 在 图 形 窗口 中 将 显示 如 图 1.50 所 示 的 表 符 号 。 


图 1.50 表 符 号 


全 注意 : 细心 的 读者 可 以 发 现 ， 此 时 的 鼠标 指针 仍然 是 四 ， 如 果 再 单 击 鼠 标 左 键 还 将 出 现 类 似 图 1.50 
所 示 的 表 符 号 ， 如 果 想 取消 该 指针 ， 可 以 单 击 工具 面板 中 的 指针 图 标 险 。 


(5) 在 图 1.50 所 示 的 表 符 号 上 双击 鼠标 左 键 ， 将 打开 Table Properties〈 表 属性 ) 对 话 框 ， 默 认 情 
况 下 选择 的 是 General 选项 卡 ， 在 该 选项 卡 的 Name 文本 框 中 输入 表 的 名 字 tb_admin， 此 时 在 Code 文 
本 框 中 也 将 自动 显示 tb_admin， 其 他 选项 选择 默认 即 可 。 

(6) 选择 Columns 选项 卡 ， 首 先 单 击 列 输入 列表 的 第 一 行 ， 将 自动 填写 一 行 信息 ， 然 后 将 Name 
列 修改 为 id， 同时 Code 列 也 将 自动 显示 为 id， 再 在 Data Type 列 中 选择 integer unsigned 列表 项 ， 最 后 
选中 P 列 的 复 选 框 ， 此 时 M 列 的 复 选 框 也 将 自动 选中 。 

(7) 按照 步骤 (6) 的 方法 再 添加 两 个 列 name 和 pwd， 如 图 1.51 所 示 。 

(8) 在 图 1.51 中 单 击 “ 应 用 ”按钮 后 ， 双 击 id 列 的 内 容 ， 将 打开 Column Properties〈 列 属性 ) 
对 话 框 ， 如 图 1.52 所 示 。 默 认 选 择 General 选项 卡 ， 在 该 选项 卡 中 ， 选 中 Identity 复 选 框 ， 此 项 操作 用 


于 设置 id 列 为 自动 编号 列 。 
和 乡 
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mi Table Properties - tb_admin (tb_admin) 


Mapping | Notes | Rules | Dependencies | Extended Dependencies | Version Info | 


General 


Colunns | Indexes | Keys 


锯 |' 昌 因 芭 | 3 昌 访 X| 的 VW 


= 


| Check | Seript | Options | Preview | 


int 
varchar(50) 
varchar(50) 


图 1.51 Columns 选项 卡 
二 
Jotes Rules | Dependencies | Version Info | 
Genersl | Detail | Standard Checks | Additional Checks | 
Name: 和 回 
Eode: 加 f= 
Commenk 剧 
天 
Table Ta 回 
Data ype: FE z][?|] Fm Displayed 
taro [六 peer 「 
Doman: Ey 了 器 
Primaykey FF Foeonkey FP Mandatoy 


图 1.52 ”Columns 列 属性 对 话 框 


(9) 单 击 “ 应 用 ”按钮 后 ， 再 单 击 “ 确 定 ” 按 钮 ， 关 闭 Column Properties 对 话 框 。 
(10) 单 击 “ 确 定 ” 按 钮 ， 关 闭 Table Properties 对 话 框 ， 完 成 tb_admin 表 的 创建 。 
(11) 按照 步骤 (4) 一 步骤 (10) 的 方法 创建 本 系统 中 的 其 他 数据 表 。 创建 完成 的 模型 图 如 图 1.53 


所 示 。 
tb_info 
tb_advertising 这 int py 
Pp! 
th admin | nt < || type varchar (30) 
id int 《pk> ||tite varchar(100) title varchar (50) 
name varchar(50) content varchar(500) content varchar(500) 
pwd varchar (50) fdate datetime linkman varchar (20) 
flag int(l) tel varchar (30) 
checkstate int(1) 
edate datetime 


RS 


1.53 九 九 度 供求 信息 网 的 模型 图 


tb_leaguerinfo 
id int 《pk> 
type varchar(20) 
title varchar (50) 
content varchar(500) 
linkman varchar (20) 
tel varchar (30) 
sdate date 
showday date 
checkstate int(1) 
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准 技巧 : 在 默认 情况 下 ， 创 建 后 的 表 符 号 中 的 全 部 文字 均 为 常规 样式 的 宋体 8 号 守 ， 如 果 想 修改 广 
字 的 格式 , 可 以 选中 全 部 表 符号 , 按 CtrlHT 键 , 在 打开 的 Symbol Format 对 话 框 中 选择 Font 
选项 卡 ， 在 该 选项 卡 中 设置 相关 内 容 的 字体 及 样式 和 字号 等 。 

(12) 选择 PowerDesigner/Database/Generate Database 命令 ， 将 打开 Database Generation 对 话 框 ， 

在 该 对 话 框 中 设置 导出 的 脚本 文件 的 名 称 〈 如 pursey.sql) 及 保存 路 径 (如 F\pursey) ， 在 下 方 的 各 个 

选项 卡 中 设置 相关 的 导出 内 容 ， 设 置 完毕 后 ， 单 击 “ 确 定 ” 按 钮 ， 导 出 数据 库 脚本 文件 完成 。 

[说 明 : 通过 以 上 方法 导出 的 脚本 文件 ， 可 以 在 MySQL 的 客户 端 命令 行 窗口 中 通过 source 命令 执 
行 ， 并 创建 相应 的 数据 表 。 


1.5.4 创建 数据 库 及 数据 表 
结合 实际 情况 及 对 用 户 需 求 的 分 析 , 可 知 九 九 度 供求 信息 网 中 应 用 的 db_pursey 数据 库 主 要 包含 如 
下 4 个 数据 表 ， 如 图 1.54 所 示 。 


加 服务 器 : localhost 蝇 数据 库 : db_pursey 
表 类 型 整理 说 明 
tb_admin MylSAM ”gb2312_chinese_ci 管理 员 信息 表 


tb_advertising MyISAM gb2312_chinese_ci 企业 广告 信息 表 
tb_info MyISAM gb2312_chinese_ci 免费 供求 信息 表 
th_leaguerinfo MylSAM gb2312_chinese_ci 付费 供求 信息 表 


图 1.54 九 九 度 供求 信息 网 数据 表 
各 数据 表 的 表 结 构 如 图 1.55~ 图 1.58 所 示 。 
1. tb_admin (管理 员 信 息 表 ) 
管理 员 信息 表 主要 用 于 存储 管理 员 的 信息 。 该 数据 表 的 结构 如 图 1.55 所 示 。 


加 服务 器 : localhost ， 曲 数据 库 : db_pursey》 国 表 :tb_admin 
字段 类 型 整理 Null ”默认 额外 
这 intfd) EE auto_increment 


name warchart50) gb2312_chinese_ci 是 
pwd varchar(50) gb2312_chinese_ci 是 


1.55 管理 员 信息 表 结构 
2. tb_advertising (企业 广告 信息 表 ) 
企业 广告 信息 表 主 要 用 于 存储 企业 发 布 的 广告 信息 。 该 数据 表 的 结构 如 图 1.56 所 示 。 


A 
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加 服务 器 : localhost 》 剖 数 据 库 : db_pursey》 国 表 : tb_advertising 
字段 类 型 整理 Null ”默认 额外 说 明 


这 int(4) 和 auto_increment ”自动 编号 
title Yarchar(100) gb2312_chinese_ci 再 广告 标题 


content 。 varchar(500) gb2312_chinese_ci 否 广告 内 容 
fdate datetime 发 布 时 间 
flag intt1) 推荐 状态 


图 1.56 企业 广告 信息 表 结构 
3. tb_info (免费 供求 信息 表 ) 
免费 供求 信息 表 主 要 用 于 存储 用 户 免 费 发 布 的 供求 信息 。 该 数据 表 的 结构 如 图 1.57 所 示 。 
较 服务 器 : localhost 》 晶 数据 库 : db_pursey 图 表 :tb_info 


字段 类 型 整理 Null ”默认 额外 说 明 

这 int(4) 否 auto_increment “自动 编号 
type varchart30) ”gb2312_chinese_ci 否 信息 类 型 
title varchar(50) ”gb2312_chinese_ci 理 信息 标题 
content Yarchar(500) gb2312_chinese_ci 理 信息 内 容 
linkman varchar(20) ”gb2312_chinese_ci 否 联系 人 

tel varchar(30) ”gb2312_chinese_ci 否 联系 电话 
checkstate int(1) 否 0 审核 状态 
edate datetime 否 发 布 时 间 


图 1.57 免费 供求 信息 表 结构 
4. tb_leaguerinfo( 付 费 供求 信息 表 ) 
付费 供求 信息 表 主 要 用 于 存储 付费 的 供求 信息 。 该 数据 表 的 结构 如 图 1.58 所 示 。 


加 服务 器 : localhost 加 数据 库 : db_pursey 图 表 :tb_leaguerinfo 
字段 类 型 整理 Null 默认 额外 说 明 

这 int(#) 否 auto_increment ”自动 编号 
type varchar(20) ”gb2312_chinese_ci 理 信息 类 型 
title Yarchar(50) ”gb2312_chinese_ci 理 信息 标题 
content varchar(500) gb2312_chinese_ci 理 信息 内 容 
linkman Yarchar(20) ”gb2312_chinese_ci 否 联系 人 
tel varchar(30) ”gb2312_chinese_ci 否 联系 电话 
sdate date 否 发 布 日 期 
showday date 否 截止 日 期 
checkstate int() 否 0 审核 状态 


1.58 ”付费 供求 信息 表 结 构 


S> 
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1.6 ”单元 测试 


在 现代 软件 开发 过 程 中 ， 测 试 不 再 作为 一 个 独立 的 生命 周期 ， 而 是 成 为 与 编写 代码 同步 进行 的 开发 
活动 。 单 元 测试 能 够 提高 程序 员 对 程序 的 信心 ， 保 证 程序 的 质量 ， 加 快 软件 开发 速度 ， 使 程序 易于 维护 。 


1.6.1 单元 测试 概述 


在 程序 设计 过 程 中 会 有 多 种 测试 ， 单 元 测试 只 是 其 中 的 一 种 。 单 元 测试 并 不 能 保证 程序 是 完美 无 
缺 的 ， 但 是 在 所 有 的 测试 中 ， 单 元 测试 是 第 一 个 环节 ， 也 是 最 重要 的 一 个 环节 。 单 元 测试 是 一 种 由 程 
序 员 自 行 测试 的 工作 。 简 单 地 说 ， 单 元 测试 就 是 测试 代码 撰写 者 依据 其 所 设想 的 方式 执行 是 否 产 生 了 
预期 的 结果 。 

单元 测试 不 仅 是 无 错 编码 的 一 种 辅助 手段 ， 还 必须 是 可 重复 的 ， 即 无 论 是 在 软件 修改 或 是 移植 到 
新 的 运行 环境 的 过 程 中 都 可 以 进行 单元 测试 。 

与 单元 测试 有 密切 关联 的 开发 活动 包括 代码 走读 (Code review) 、 静 态 分 析 〈Static analysis) 和 
动态 分 析 (Dynamic analysis) 。 代 码 走读 就 是 对 软件 的 源 代码 进行 宏观 地 阅读 ， 整 理 开发 思路 。 静 态 
分 析 就 是 对 软件 的 源 代码 进行 研读 ， 查 找 错 误 或 收集 一 些 度量 数据 ， 并 不 需要 对 代码 进行 编译 和 执行 。 
动态 分 析 就 是 通过 观察 软件 运行 时 的 动作 ， 来 提供 执行 跟踪 、 时 间 分 析 以 及 测试 覆盖 度 方面 的 信息 。 


1.6.2 ”单元 测试 的 优点 


单元 测试 具有 以 下 优点 : 

一 种 验证 行为 。 程 序 中 的 每 一 项 功能 都 是 用 测试 来 验证 它 的 正确 性 ， 为 以 后 的 开发 提供 支援 。 
就 算是 开发 后 期 ， 也 可 以 轻松 地 增加 功能 或 更 改 程序 结构 ， 而 不 用 担心 这 个 过 程 中 会 破坏 重 
要 的 东西 ， 而 且 它 为 代码 的 重 构 提供 了 保障 。 这 样 ， 我 们 就 可 以 更 自由 地 对 程序 进行 改进 。 

一 种 设计 行为 。 编 写 单元 测试 将 使 用 户 从 调用 者 观察 、 思 考 。 特 别 是 先 写 测试 (test-first》， 

迫使 设计 者 把 程序 设计 成 易于 调用 和 可 测试 的 ， 即 解除 软件 中 的 耦合 。 

一 种 编写 文档 的 行为 。 单 元 测试 是 一 种 无 价 的 文档 ， 它 是 展示 函数 或 类 如 何 使 用 的 最 佳 文档 。 
这 份 文档 是 可 编译 、 可 运行 的 ， 并 且 它 保持 最 新 ， 永 远 与 代码 同步 。 

具有 回归 性 。 自 动 化 的 单元 测试 避免 了 代码 出 现 回归 ， 编 写 完成 之 后 ， 可 以 随时 随地 地 快速 
运行 测试 。 


回 


加 


1.7 前台 首页 设计 


1.7.1 前台 首页 概述 


网 站 主页 是 关于 网 站 的 建设 及 形象 宣传 ， 它 对 网 站 生存 和 发 展 起 着 非常 重要 的 作用 ， 应 该 是 一 个 


¥ 
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信息 含量 较 高 、 内 容 较 丰富 的 宣传 平台 。 九 九 度 供求 信息 网 前 台 首 页 主要 包含 以 下 内 容 : 


因 办 轨 


网 站 菜单 导航 (包括 公寓 信息 、 招 聘 信息 、 求 职 信息 、 培 训 信息 、 家 教 信息 、 房 屋 信息 、 车 
辆 信息 、 求 购 信息 、 出 售 信息 、 招 商 引 资 、 寻 人 / 物 启示 等 ) 。 

发 布 免费 的 供求 信息 《包括 公寓 信息 、 招 聘 信息 、 求 职 信息 、 培 训 信息 、 家 教 信 息 、 房 屋 信 
息 、 车 辆 信息 、 求 购 信息 、 出 售 信息 、 招 商 引 资 、 寻 人 / 物 启示 等 ) 。 

推荐 供求 信息 显示 包括 公寓 信息 、 招 聘 信息 、 求 职 信息 、 培 训 信息 、 家 教 信息 、 房 屋 信息 、 
车 辆 信息 、 求 购 信息 、 出 售 信息 、 招 商 引资 、 寻 人 / 物 启示 等 ) ， 其 中 ， 付 费 信息 按时 间 顺 序 
降序 排列 ， 免 费 信息 按时 间 顺 序 分 页 显示 。 

显示 推荐 的 企业 广告 信息 。 

供求 信息 快速 检索 : 支持 模糊 查询 和 查询 关键 字 描 红 功 能 。 

后 台 登 录入 口 : 为 管理 员 进 入 后 台 提 供 一 个 入 口 。 


下 面 看 一 下 本 案例 中 提供 的 前 台 首 页 ， 该 页 面 在 本 书 光盘 中 的 路 径 为 \TM\01\99pursey\index.php， 
如 图 1.59 所 示 。 


和 要 发 布 )( 管理 员 登 录 ) (加 和 


『 公 寅 信息 1 高档 平 博 女 子 公 

位 于 市 中 心 ,4 楼 阳 面 # 内 设 四 人 间 ,五 人 间 ， 新 购置 标准 平 铺 单 人 床 ,新 被 衡 床 单 。 单 独 
客厅 ,方便 起 居 。 有 栈 电视 ,新 用 千古 ,衣柜 ,床头柜 , 柱 具 t 可 歼 饭 ， 可 月 交房 费 * 内 住 均 
为 有 相对 稳定 工作 的 女孩 4 室内 温 坝 ， 安 欧 * 专人 管理 # 是 高 素质 白领 女性 的 温 心 家 园 


ABCDEFG 


明日 夜校 教 你 说 最 正宗 


人 寅 合 息 昌 心 愉 : 女 子 公 寅 2007-12-20 09:40;58 内 容 显示 区 
本 全 富 位 于 者 用 街 , 交通 便利 ,环境 好 , 现 入住 人 员工 作 灼 定 雪 后 高 ， 欢迎 有 区 定 工作 爱 二 


净 娘 防 入 储 。 有 不 tint 并 


九 九 度 供 录 信息 同 
联系 地 址 : 吉林 省 长 春 市 s+* 街 * 号 
民 庚 路 附近 ,交通 便利 , 内 设 吉本 加 可 以 人 角 。 选 衣 机 ,饮水 机 ,电视 机 ,24 小 时 冷 起 水 
等 一 供 三 好 ， 全 者 被 和 ， 宽 茂 明 充 ,环境 啤 登 清净， 安全 卫生 , 鹿 钴 欢迎 各 界 高 雪 质 单身 男士 
菌 来 入 住 
联系 人 : 可 先生 1 2 
『 公 寅 信息 4 必 子 公 2007-12-20 09:33:53 


be pe 提供 2 人 间 , 8 人 同 。 交通 便利 ,室内 千 净 。 整洁 ,通风 好 。 有 甩 千 简 。 
悍 ， 亲 上 化 专人 管理 ,是 理 起 的 公 寅 选择 ， 


图 1.59 九 九 度 供求 信息 网 首页 
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各 区 域 的 介绍 及 所 对 应 的 PHP 文件 如 表 1.3 所 示 。 
表 1.3 页面 框架 中 各 区 域 介绍 及 对 应 PHP 文件 


名 称 说 了 明 对 应 PHP 文件 
导航 栏 提供 查看 各 类 信息 的 超 链接 topphp 
信息 检索 区 企业 广告 显示 及 各 类 信息 检索 left.php 


内 容 显 示 区 根据 用 户 请 求 显示 相应 内 容 


显示 版 权 信息 


根据 请 求 加 载 相 应 的 PHP 文 件 , 默认 加 载 main php 


1.7.2 前 台 首 页 技术 分 析 


超 链接 在 本 质 上 属于 一 个 网 页 的 一 部 分 ， 它 是 一 种 允许 用 户 同 其 他 网 页 或 站 点 之 间 进 行 连接 的 元 
素 。 各 个 网 页 链接 在 一 起 后 ， 才 能 真正 构成 一 个 网 站 。 按 照 使 用 对 象 的 不 同 ， 网 页 中 的 链接 可 以 分 为 
文本 超 链接 、 图 像 超 链接 、E-mail 链接 、 锚 点 链接 、 多 媒体 文件 链接 和 空 链接 等 。 

图 像 不 但 可 以 建立 超 链接 ， 还 可 以 实现 图 像 映射 。 图 像 映射 是 指 一 幅 图 像 可 以 建立 多 个 超 链 接 ， 


本 项 目 就 是 应 用 图 像 热 区 实现 的 功能 导航 。 

图 像 映射 有 两 种 : 服务 器 端 映射 (Server-side Image Map) 和 客户 端 映射 (Client-side Image Map ) 。 
目前 使 用 最 多 的 是 客户 端 映射 , 因为 客户 端 映射 使 图 像 上 对 应 区 域 的 坐标 以 及 链接 的 URL 地 址 都 在 浏 
览 器 端 读 入 ， 省 去 和 服务 器 之 间 互 传 坐标 和 URL 的 时 间 。 

在 PHP 文件 中 ， 使 用 <MAP> 标 记 创建 图 像 映射 。 语 法 如 下 : 

<IMG SRC= “file name” USEMAP= “#MapName” > 

<MAP NAME= “MapName” > 


<AREA SHAPE=“value” COORDS=“ 坐 标 ” HREF=“URL” ALT=“ 描 述 文字 ”> 
<AREA SHAPE=“value” COORDS=“ 坐 标 ” HREF=“URL” ALT=“ 描 述 文字 ”> 


</MAP> 
在 <IMG> 标 记 中 设置 属性 USEMAP， 确 定 创建 图 像 映射 。<MAP> 标 记 的 属性 如 表 1.4 所 示 。 
表 1.4 <MAP> 标 记 的 属性 


<MAP> 标 记 的 属性 描述 
NAME 图 像 映射 的 名 称 
SHAPE 定义 图 像 映射 区 域 的 名 称 
COORDS 设 定 区 域 坐标 
HREF 设 定 区 域 的 链接 地 址 
ALT 设 定 区 域 链接 的 描述 文字 


在 <MAP> 标 记 中 ， 根 据 属性 SHAPE 的 取 值 不 同 ， 相 应 坐标 的 设 定 也 不 同 。 下 面 介绍 属性 SHAPE 


的 3 种 取 值 以 及 相应 坐标 的 设 定 。 
.33 。 多 
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设 定 属性 SHAPE 的 属性 值 为 rect。 属 性 SHAPE 取 值 为 rect， 表 示 和 矩形 区 域 ， 属 性 COORDS 
的 坐标 形式 为 “X1，Y1，X2，Y2”。 其 中 ，X1、Y1 代表 矩形 左上 角 的 X 坐标 和 YY 坐标 
X2、Y2 代表 矩形 右 下 角 的 X 坐标 和 Y 坐标。 

回 设 定 属性 SHAPE 的 属性 值 为 circle。 属 性 SHAPE 取 值 为 circle, 表示 圆 形 区 域 , 属性 COORDS 

的 坐标 形式 为 “X，Y，r”。 其 中 ，X、Y 为 圆心 坐标 ，r 为 圆 的 半径 。 

设 定 属性 SHAPE 的 属性 值 为 poly。 属 性 SHAPE 取 值 为 poly, 表示 多 边 形 区 域 , 属性 COORDS 

的 坐标 形式 为 “X1，Y1，X2，Y2，…”。 其 中 ，Xn、Yn 代表 构成 多 边 形 每 一 点 的 坐标 值 ， 

n 的 取 值 为 1 ， 2，3，…。 多 边 形 有 几 边 就 有 几 对 X、Y 坐标 。 

下 面 在 Dreamweaver 编辑 器 中 创建 图 像 映射 ， 单 击 图 像 不 同 区 域 ， 链 接 到 不 同 的 文件 。 创 建 图 像 
映射 的 步骤 如 下 : 
(1) 在 Dreamweaver 编辑 器 中 选中 所 要 编辑 的 图 像 ， 在 属性 窗口 中 ， 有 3 种 形状 的 热点 工具 ， 分 

别 为 矩形 热点 工具 、 圆 形 热点 工具 、 多 边 形 热点 工具 。 

(2) 选择 一 种 热点 工具 ， 在 图 像 上 按 住 鼠标 左 键 拖 动 ， 确 定 所 选区 域 。 

(3) 设置 区 域 属性 ， 在 “链接 ”文本 框 中 输入 所 要 链接 书签 的 名 称 ， 在 “替代 ”文本 框 中 输入 区 
域 链接 文件 ， 如 index.php。 

(4) 重复 步骤 (2) 、 (3) ， 在 图 像 上 定义 不 同 的 区 域 链接 。 


加 


1.7.3 前 台 首 页 的 实现 过 程 


本 系统 中 所 有 的 前 台 页 面 都 采用 了 二 分 栏 结 构 ， 分 为 导航 栏 、 信 息 检索 区 、 内 容 显示 区 和 版 权 区 4 
个 区 域 。 为 了 方便 网 站 的 日 后 维护 ， 将 这 4 个 区 域 形 成 单独 的 PHP 文件 ， 然 后 应 用 include 语句 将 这 4 
个 文件 包含 进来 。 前 台 首页 文件 的 代码 如 下 : 

例 程 01 ”代码 位 置 ， 光 盘 \TM\01\99pursey\index.php 


<table width="780" border="0" align="center" cellpadding="0" cellspacing="0"> 
<tr valign="top"> 
<td colspan="2"><?php include("top.php"):;?></td> <!-- 包含 导航 文件 --> 
</tr> 
<tr> 
<!-- 包含 信息 检索 文件 -> 
<td width="217" valign="top" background="Images/line2.gif"><?php include("left.php"):?></td> 
<!-- 包含 内 容 显 示 文件 -> 
<td width="586" valign="top" bgcolor="#FEFEF6"><?php include("main.php");?></td> 
</tr> 
<tr> 
<td colspan="2"><?php include("bottom.php"):?></td> <!-- 包含 版 权 信息 文件 -> 
<t> 


</table> 

其 中 ， 导 航 文件 top.php 页 应 用 了 图 像 映射 来 创建 文件 的 超 链接 ， 代 码 如 下 : 
例 程 02 ”代码 位 置 : 光盘 \TM\01\99pursey\top.php 

<table width="780" height="201" border="0" align="center" cellpadding="0" cellspacing="0"> 


S> 
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<tr> 
<td height="38"><img sre="Images/banner.gif" width="780" height="202" border="0" usemap="#Map"></td> 


<area shape="rect" coords="613,9,666,27" 
‘onClick="this.style.behavior="url(#default#homepage)';this.: 1 php');"> 
收藏 


<area shape="rect" coords="535,8,593,26" 
href="javascript:window.extermal.AddFavorite('http://localhost/99pursey/index.php',' 九 九 度 供求 信息 网 )"> 


<area shape="rect" coords="448,8,516,26" href="admin/login.php"> <!-- 后 台 登 录 页 --> 
<area shape="rect" coords="356,8,424,28" href="release.php"> <!-- 发 布 信息 页 --> 
<area shape="rect" coords="680,61,753,82" href="search.php"> <!-- 寻 人 / 物 启示 信息 页 --> 
<area shape="rect" coords="579,62,637,82" href="sale.php"> <!-- 出 售 信息 页 --> 
<area shape="rect" coords="483,62,536,83" href="car.php"> <!-- 车 辆 信息 页 --> 
<area shape="rect" coords="385,62,441,83" href="teaching.php"> <!-- 家 教 信息 页 --> 
<area shape="rect" coords="290,61,344,83" href="seekjob.php"> <!-- 求职 信息 页 --> 
<area shape="rect" coords="678,38,740,58" href="recruitbusiness.php"> <!-- 招商 引资 信息 页 --> 
<area shape="rect" coords="579,38,635,58" href="seekbuy.php"> <!-- 求购 信息 页 --> 
<area shape="rect" coords="482,38,541,58" href="house.php"> <!-- 房屋 信息 页 --> 
<area shape="rect" coords="381,39,440,60" href="foster.php"> <!-- 培训 信息 页 --> 
<area shape="rect" coords="290,39,345,59" href="invitejob.php"> <!-- 招聘 信息 页 --> 
<area shape="rect" coords="204,39,263,86" href="index.php"> <!-- 首页 -> 

</map> 


1.8 ”免费 供求 信息 发 布 模块 设计 


1.8.1 免费 供求 信息 发 布 模块 概述 


免费 供求 信息 的 发 布 提 供 对 象 为 供求 信息 用 户 ， 是 供求 信息 网 站 非常 重要 的 功能 ， 也 是 供求 信息 
网 站 的 核心 功能 。 

免费 供求 信息 发 布 模块 可 以 完成 11 种 不 同类 别 信息 的 发 布 。 用 户 可 以 根据 自身 需要 将 供求 信息 发 
布 到 相应 的 信息 类 别 中 《〈 共 包括 11 个 信息 类 别 : 公寓 信息 、 招 聘 信息 、 求 职 信息 、 培 训 信息 、 家 教 信 
息 、 房 屋 信息 、 车 辆 信息 、 求 购 信息 、 出 售 信息 、 招 商 引资 、 寻 人 / 物 启 示 等 类 型 供求 信息 ) 。 信 息 发 
布 成 功 后 ， 需 要 管理 员 进行 审核 ， 只 有 审核 成 功 的 信息 才能 显示 在 前 台 相 应 的 信息 类 别 网 页 中 。 免 费 
供求 信息 发 布 的 流程 如 图 1.60 所 示 。 
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人 


管理 员 


图 1.60 “免费 供求 信息 发 布 流程 图 
1.8.2 ”免费 供求 信息 发 布 模块 技术 分 析 


本 模块 实现 免费 供求 信息 发 布 功能 主要 应 用 到 如 下 儿 个 函数 ， 下 面 进行 详细 介绍 。 
1. mysql_connect() 函 数 
打开 一 个 到 MySQL 服务 器 的 连接 。 如 果 成 功 则 返回 一 个 MySQL 连接 标识 ， 失 败 则 返回 false。 
语法 如 下 : 
resource mysql_connect ( [string server [, string username [, string password [, bool new_link [, int client_flags]]]]] ) 
mysql_connect0 函 数 的 参数 说 明 如 表 1.5 所 示 。 
表 1.5 mysql_connect() 函 数 的 参数 说 明 


参数 说 了 明 
MySQL 服 务 器 。 可 以 包括 端口 号 ， 例 如 "hostname:port"， 或 者 到 本 地 套 接 字 的 路 径 ， 例 如 对 于 localhost 
2 的 ":/path/to/socket"。 如 果 _ PHP 指令 mysqlLdefault_host 未 定义 〈 默 认 情 况 ) ， 则 默认 值 是 'localhost:3306' 
usemame “| 用 户 名 。 默 认 值 是 服务 器 进程 所 有 者 的 用 户 名 
_password 密码 。 默 认 值 是 空 密码 
如 果 用 同样 的 参数 第 二 次 调用 mysql_connect() 函 数 , 将 不 会 建立 新 连接 , 而 将 返回 已 经 打开 的 连接 标识 。 
new_link 参数 new_link 改 变 此 行为 并 使 mysql_connect() 函 数 总 是 打开 新 的 连接 ， 其 至 当 mysql_connect0) 函 数 曾 在 


前 面 被 同样 的 参数 调用 过 
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说 了 明 
client_flags 参 数 可 以 是 以 下 常量 的 组 合 : MYSQL _CLIENT _SSL、MYSQL _CLIENT_COMPRESS 、 
MYSQL CLIENT IGNORE SPACE 或 MYSQL CLIENT INTERACTIVE 


参数 


client_flags 


2. mysql_select db() 函 数 
选择 MySQL 数据 库 。 如 果 成 功 返回 tue， 失 败 返回 false。 语 法 如 下 : 
bool mssql_select db ( string database_name [, resource link_identifier] ) 

mysql_select db() 函 数 设 定 与 指定 的 连接 标识 符 所 关联 的 服务 器 上 的 当前 激活 数据 库 。 如 果 没 有 指 
定 连 接 标识 符 , 则 使 用 上 一 个 打开 的 连接 。 如 果 没 有 打开 的 连接 , 本 函数 将 无 参数 调用 mysql_connect() 
函数 来 尝试 打开 一 个 并 使 用 之 。 每 个 其 后 的 mysql_query0 函 数 调用 都 会 作用 于 活动 数据 库 。 

下 面 应 用 mysql_connect() 函 数 连接 MySQL 服务 器 ， 然 后 应 用 mysql_select_db() 函 数 连接 MySQL 
数据 库 ， 代 码 如 下 : 


<?php 

$conn = mysql_connect("localhost", "root", "root"); /连接 MySQL 服 务 器 
$db=mysql_select_db("db_pursey", Sconn) or die (" 数 据 库 连 接 失败 : " .mysql_error()); /连接 数据 库 db _pursey 
mysql_ query("set names gb2312"); /采用 GB2312 编 码 方式 
7> 


3. mysql_query() 函 数 
mysql_query() 函 数 用 来 根据 连接 标识 符 向 该 数据 库 服 务 器 的 当前 数据 库 发 送 查 询 。 语 法 格式 如 下 : 
int mysql_query(string query ,int [link_identifier]); 
其 中 ，query 是 查询 字符 串 ;， link_identifier 是 数据 库 连 接 标识 符 。 
mysql_query() 函 数 在 执行 成 功 时 返回 一 个 结果 标识 符 ， 失 败 时 返回 false。 
4. date() 函 数 
date0) 函 数 主要 用 于 格式 化 一 个 本 地 时 间 / 日 期 。 语 法 如 下 : 
string date ( string format , int timestamp) 
该 函数 返回 将 参数 timestamp 按照 指定 格式 格式 化 而 产生 的 字符 串 ,其 中 参数 timestamp 是 可 选 的 ， 
默认 值 为 time0， 即 如 果 没有 给 出 时 间 戳 则 使 用 本 地 当前 时 间 。 
date0) 函 数 的 参数 format 的 格式 化 选项 如 表 1.6 所 示 。 
表 1.6 参数 format 的 格式 化 选项 
参 数 说 了 明 
小 写 的 上 午 和 下 午 值 ， 返 回 值 am 或 pm 
大 写 的 上 午 和 下 午 值 ， 返 回 值 AM 或 PM 
Swatch Intemet 标 准时 ， 返 回 值 000 一 999 
月 份 中 的 第 几 天 ， 有 前 导 零 的 2 位 数字 ， 返 回 值 01 一 31 
星期 中 的 第 几 天 ， 文 本 格式 ，3 个 字母 ， 返 回 值 Mon 一 Sun 


已 |=| 四 |> Is 


PHP 项 目 开发 全 程 实录 


续 表 


$ 
涟 


说 有明 

月 份 ， 完 整 的 文本 格式 ， 返 回 值 January 一 December 
小 时 ，12 小 时 格式 ， 没 有 前 导 零 ， 返 回 值 1 一 12 
小 时 ，24 小 时 格式 ， 没 有 前 导 零 ， 返 回 值 0 一 23 
小 时 ，12 小 时 格式 ， 有 前 导 零 ， 返 回 值 01 一 12 
小 时 ，24 小 时 格式 ， 有 前 导 零 ， 返 回 值 00 一 23 
有 前 导 零 的 分 钟 数 ， 返 回 值 00 一 59 
判断 是 否 为 夏令 时 ， 返 回 值 如 果 是 夏令 时 为 1， 否 则 为 0 

j 月 份 中 的 第 几 天 ， 没 有 前 导 零 ， 返 回 值 1 一 31 
星期 数 ， 完 整 的 文本 格式 ， 返 回 值 Sunday 一 Saturday 
判断 是 否 为 半年 ， 返 回 值 如 果 是 冰 年 为 1， 否 则 为 0 
数字 表示 的 月 份 ， 有 前 导 零 ， 返 回 值 01 一 12 
3 个 字母 缩写 表示 的 月 份 ， 返 回 值 Jan 一 Dec 
数字 表示 的 月 份 ， 没 有 前 导 零 ， 返 回 值 1 一 12 
与 格林 威 治 时 间 相 差 的 小 时 数 ， 例 如 : 0200 
RFC 822 格式 的 日 期 ， 例 如 : Thu，21 Dec 2000 16: 01: 07 +0200 
秒 数 ， 有 前 导 零 ， 返 回 值 00 一 59 

每 月 天 数 后 面 的 英文 后 级 ，2 个 字符 ， 例 如 st，nd，rd 或 者 由。 可 以 和 j 一 起 使 用 

指定 月 份 所 应 有 的 天 数 
本 机 所 在 的 时 区 
从 Unix 纪 元 〈January 1 1970 00:00:00 GMT) 开始 至 今 的 秒 数 
星期 中 的 第 几 天 ， 数 字 表 示 ， 返 回 值 为 0 一 6 
ISO-8601 格 式 年 份 中 的 第 几 周 ， 每 周 从 星期 一 开始 
4 位 数字 完整 表示 的 年 份 ， 返 回 值 如 1998、2008 

y 2 位 数字 表示 的 年 份 ， 返 回 值 如 88 或 08 

六 年 份 中 的 第 几 天 ， 返 回 值 0 一 366 
时 差 偏 移 量 的 秒 数 。UTC 西 边 的 时 区 偏 移 量 总 是 负 的 ，UTC 东边 的 时 区 偏 移 量 总 是 正 的 ， 返 回 值 为 
一 43200 一 43200 


一 | 


ml l= lo ls lz |3 Ic |~— 


< 三 |z |c |- |- 


Zz 


全 注意 : 有 效 的 时 间 蕉 典 型 范围 是 格林 成 治 时 间 1901 年 12 月 13 日 20:45:54 到 2038 年 1 月 19 日 
03:14:07 (此 范围 符合 32 位 有 符号 整数 的 最 小 值 和 最 大 值 ) 。 在 Windows 系统 中 此 范围 限 
制 为 从 1970 年 1 月 1 日 到 2038 年 1 月 19 日 。 
例如 应 用 date0 函 数 格式 化 一 个 日 期 ， 并 输出 日 期 的 值 ， 代 码 如 下 : 
<?php 
echo date("y:m:d"); 
?> 


结果 为 : 07:07:11 


RS 
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1.8.3 ”免费 供求 信息 发 布 模块 的 实现 过 程 


国 ”免费 供求 信息 发 布 使 用 的 数据 表 : tb_info 

用 户 通 过 单 击 前 台 页 面 导 航 栏 的 “我 要 发 布 ” 超 链接 ， 进 入 信息 发 布 页 面 ， 如 图 1.61 所 示 。 程 序 
会 先 验证 用 户 是 否 输入 的 信息 ， 若 验证 失败 ， 则 返回 信息 发 布 页 面 ， 进 行 相应 提示 。 若 验证 成 功 ， 则 
向 数据 库 中 插入 记录 ， 完 成 发 布 操作 。 


:人 2 再 信息 - 。 同 。。 请 正确 选择 您 要 发 布 的 信息 类 别 


信息 标题 : 白领 女子 公寓 ] 


全 要 衍 附 过，2 悉 ， 提 供 2 人 间 ，8 人 间 。 交 通 便 利 ， 室 内 
净 ， 整 洁 ， 通 风 好 ， 有 甩 干 简 ， 有 电视 ， 提 供 热 水 。 价 


用 干 
合理 ， 亲 情 化 考 人 管理 ， 是 理想 的 公寓 选择 。 


联系 人 : 攻 网 络 | 
村 发布 信 筷 
图 1.61 免费 供求 信息 发 布 网 页 


在 功能 导航 页 top.php 中 ， 在 “我 要 发 布 ” 图 像 上 添加 图 像 映射 ， 并 绘制 热 区 ， 代 码 如 下 : 
例 程 03 ”代码 位 置 : 光盘 \TM\01\99pursey\top.php 


<map name="Map"> // 图 像 映射 
<area shape="rect" coords="356,8,424,28" href="release.php"> 
</map> 


在 信息 发 布 页 面 选 择 要 发 布 的 信息 类 型 后 ， 填 写真 实 有 效 的 供求 信息 。 为 了 避免 用 户 添加 空 信息 ， 
在 单 击 “ 发 布 信息 ”按钮 时 ， 应 用 JavaScript 脚本 自 定义 一 个 checkform() 函 数 ， 验 证 提交 的 表单 各 元 
素 是 否 为 空 值 ， 如 果 为 空 ， 则 弹出 提示 信息 ， 并 将 焦点 定位 到 为 空 值 的 表单 元 素 。 代 码 如 下 : 


例 程 04 ”代码 位 置 ， 光盘 \TM\01\99pursey\release_content.php 
<script language="javascript"> 


function checkform(form){ // 自 定义 一 个 JavaScript 函 数 checkform() 
for(i=0;i<form.length;i++){ /应 用 for 循 环 语句 检索 fomm 表 单元 素 的 值 是 否 为 空 
if(form.elements[i].value—""){ /如 果 form 表 单 中 某 个 元 素 值 为 空 
alert(" 请 将 发 布 信息 填写 完整 ! "); // 弹 出 提示 信息 
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form.elements[i].focus(); // 将 焦点 的 值 定位 到 为 空 值 的 表单 元 素 
retum false; // 返 回 焦点 


} 
} 


</script> 
创建 与 数据 库 db_pursey 的 连接 ， 代 码 如 下 : 
例 程 05 ”代码 位 置 ， 光盘 \TM\01\99pursey\conn\conn.php 


<?php 
S$link=mysql_connect("localhost","root","root"); // 连 接 MySQL 服 务 器 
mysql_select_db("db_pursey ",$link); // 连 接 MySQL 数 据 库 文件 db_pursey 
mysql_query("set names gb2312"); // 采 用 GB2312 编 码 方式 
> 

Ah 代 码 贴 十 


@ mysql_connect() 函 数 : 连接 MySQL 服务 器 ， 详 细 讲解 参见 1.8.2 节 。 

@ mysql select db) 函数: 连接 MySQL 数据 库 文 件 ， 详 细 讲解 参见 1.8.2 节 。 

@ mysql_ query() 函 数 : 该 函数 用 来 向 数据 库 服务 器 发 送 编码 方式 ， 详 细 讲解 参见 1.8.2 节 。 

提交 表单 信息 到 数据 处 理 页 ， 应 用 insert…into 语句 向 免费 供求 信息 表 中 添加 供求 信息 。 如 果 信 息 
添加 成 功 ， 则 弹出 成 功 的 信息 提示 ; 否则 弹出 失败 的 提示 信息 。 代 码 如 下 : 

例 程 06 ”代码 位 置 ， 光盘 \TM\01\99pursey\release_ok.php 


<2php 
include("conn/conn.php"); // 连 接 数 据 库 文件 
$type=$_POST[type]; // 获 取信 息 类 型 
$title=$_POSTI[title]; // 获 取信 息 标题 
$content=$_POST[content]; // 获 取信 息 内 容 
Slinkman=$_POST[linkman]; // 获 取 联 系 人 
S$tel=$_POST[tel]; // 获 取 联 系 电话 
© $edate=date("Y-m-d h:i:s"); // 获 取 发 布 时 间 
@ $sql=mysql query("insert into tb info(type,title,content,linkman,tel,checkstate,edate) 
values('$type','$title','$content','$linkman','Stel',0,'Sedate’)"); // 将 免费 的 供求 信息 添加 到 数据 表 中 
if($sqD){ // 如 果 添 加 操作 成 功 ， 则 弹出 提示 信息 
echo "<script>alert(' 蕉 喜 您 ， 信 息 发 布 成 功 ! ");window .location.href='release.php';</script>"; 
jelse{ // 如 果 添 加 操作 失败 ， 则 弹出 提示 信息 
echo "<script>alert(' 对 不 起 ， 信 息 发 布 失败 ! '):history.backO;</script>"; 
} 
> 
< 代码 贴 十 


@ date: 格式 化 一 个 本 地 时 间 / 日 期 ， 详 细 讲 解 参见 1.8.2 节 。 
@ insert into: 向 指定 的 数据 表 中 添加 数据 信息 。 


SS 
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1.9 ”信息 检索 模块 设计 


1.9.1 信息 检索 模块 概述 


信息 检索 是 对 已 存在 于 数据 库 中 的 数据 按 条 件 进 行 筛选 浏览 ， 是 查看 历史 信息 和 确认 数据 操作 最 
为 快速 、 有 效 的 办 法 。 信 息 检索 模块 主要 通过 选择 信息 类 型 和 输出 查询 关键 字模 糊 查询 供求 信息 资源 ， 
并 输出 查询 结果 。 考 虑 到 供求 信息 的 信息 量 较 大 ， 因 此 本 模块 对 与 查询 关键 字 相 匹配 的 查询 结果 进行 
描 红 ， 从 而 方便 用 户 的 浏览 。 信 息 检 索 模 块 的 示意 图 如 图 1.62 所 示 。 


设置 查询 条 件 


根据 需要 组 合 检索 式 


输出 查询 结果 
查询 关键 字 描 红 


图 1.62 信息 检索 模块 的 示意 图 
1.9.2 ”信息 检索 模块 技术 分 析 


在 对 数据 进行 查询 后 ， 最 终 需 要 将 查询 结果 显示 在 页 面 中 反馈 给 浏览 者 。 在 PHP 中 ， 查 询 结果 的 
显示 方式 有 很 多 种 ， 最 常用 的 就 是 表格 显示 方式 。 因 为 采用 这 种 方式 显示 的 数据 条 理 清晰 、 简 捷 明了 。 
在 利用 表格 显示 查询 结果 时 , 通常 是 将 查询 结果 保存 在 结果 集中 , 然后 需要 使 用 do…while 循环 将 
其 查询 结果 显示 出 来 。 需 要 注意 的 是 ， 需 要 先 判断 查询 结果 是 否 为 宝 ， 只 有 查询 结果 不 为 宝 时 ， 才 可 


。41。 
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以 使 用 循环 语句 显示 数据 。 为 了 使 读者 更 好 地 理解 通过 表格 显示 查询 结果 ， 下 面 给 出 其 实现 流程 图 ， 
如 图 1.63 所 示 。 


图 1.63 ”信息 检索 模块 流程 图 


考虑 到 用 户 不 可 能 全 面 了 解数 据 表 中 的 数据 信息 ， 例 如 不 能 确定 所 要 查询 信息 的 内 容 、 查 询 的 主 
题 等 , 这 时 就 需要 使 用 like 进行 模糊 查询 。like 关键 字 需 要 使 用 通配符 在 字符 串 内 查找 指定 的 模式 ， 所 
以 读者 需要 了 解 通配符 及 其 含义 。 通 配 符 的 含义 如 表 1.7 所 示 。 

表 1.7 like 关键 字 中 的 通配符 及 说 明 
说 阴 
由 零 个 或 更 多 字符 组 成 的 任意 字符 串 


任意 单个 字符 
用 于 指定 范围 ， 例 如 [A~F]， 表 示 A~F 范 围 内 的 任何 单个 字符 
表示 指定 范围 之 外 的 ， 例 如 [^A~F] 表 示 A~F 范 围 以 外 的 任何 单个 字符 


如 果 想 查询 包含 “女子 公寓 ”的 信息 ， 可 以 使 用 like 运算 符 配合 通配符 “%” 完 成 。 其 SQL 语句 
如 下 : 


select * 他 om tb_info where content like '% 女 子 公寓 %'; 


如 果 想 查找 信息 类 型 为 “公寓 信息 ”或 者 内 容 为 “女子 公寓 ”的 信息 时 配合 or 运算 符 来 使 用 。 典 
SQL 语句 如 下 : 
select * from tb_info ”where type=' 公 寓 信 息 ' or content like'% 女 子 公寓 %' 


本 模块 实现 付费 信息 与 查询 关键 字 相 匹配 的 信息 的 SQL 语句 如 下 : 
\ 42 
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Stype=$_POST[type]; // 获 取信 息 类 型 

S$content=$_POST[content]; // 获 取 查 询 关 键 字 

$sqll=mysql_query("select * from tb_leaguerinfo where checkstate=1 and type='$type' and content like'%S$content%' or 
title like'%$content%' or linkman like'%$content%' or tel like’%S$content%"); 

$infol=mysql_fetch_array($sql1); /检索 付费 的 信息 

本 模块 实现 免费 信息 与 查询 关键 字 相 匹配 的 信息 的 SQL 语句 如 下 : 


$sql=mysql query("select * from tb info where checkstate=] and type=$type' and content like'%$content%' or title 
like'%$content%' or linkman like'"%S$content%' or tel like'%Scontent%'); 
$info=mysql_fetch_array($sql); // 检 索 免 费 的 信息 


各 注意 : 当 满足 数据 表 中 多 个 字段 中 的 任 一 字段 时 ， 可 以 使 用 or 运算 符 将 多 个 条 件 连接 。 


另外 ， 由 于 搜索 的 内 容 中 文字 比较 多 ， 为 了 方便 浏览 者 查找 自己 所 关注 的 内 容 信息 ， 所 以 在 搜索 
引擎 中 加 入 了 描 红 功 能 。 描 红 功 能 主要 用 str_ireplace() 函 数 实现 ， 该 函数 的 具体 讲解 读者 可 参见 本 章 的 
tl 


1.9.3 ”信息 检索 模块 的 实现 过 程 


国 ”信息 检索 模块 使 用 的 数据 表 : tb_info、tb_leaguerinfo 

在 开发 信息 检索 模块 时 ， 由 于 该 网 站 含有 大 量 的 数据 信息 ， 为 了 方便 用 户 浏 览 网 站 信息 ， 需 要 添 
加 复合 条 件 查询 实现 搜索 功能 。 在 信息 检索 区 的 “关键 字 ” 文 本 框 中 输入 和 欲 查询 的 关键 字 ， 在 “条 件 ” 
下 拉 列 表 框 中 选择 要 搜索 的 信息 类 型 ， 然 后 单 击 “ 开 始 搜索 ”按钮 ， 对 指定 条 件 的 记录 进行 检索 并 输 
出 结果 集 到 浏览 器 ， 同 时 ， 为 了 方便 浏览 者 查找 自己 所 关注 的 内 容 信息 ， 本 横 块 对 查询 关键 字 进行 描 
红 。 运 行 结果 如 图 1.64 所 示 。 


1.64 ”信息 检索 页 面 的 运行 结果 
信息 检索 页 面 中 所 涉及 到 的 重要 表单 元 素 如 表 1.8 所 示 。 
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表 1.8 信息 检索 页 面 所 涉及 的 重要 表单 元 素 


名 称 元 素 类 型 重要 属性 含义 

forml form method="post" action="findinfo.php" 表单 

content text id="content" size="20" 查询 关键 字 
<select name="type"> 

<option value=" 招 聘 信息 ">- 招 聘 信息 -</option> 

type select <option value=" 求 职 信息 ”selected>- 求 职 信息 信息 类 型 
-</option> 
</select> 

search image src="Images/btn1 .gif" onClick="retum chkinput(form)" 开始 搜索 按钮 


应 用 JavaScript 脚本 自 定义 一 个 chkinput() 函 数 ， 实 现 对 表单 提交 的 信息 进行 验证 ， 代 码 如 下 : 
例 程 07 ”代码 位 置 ， 光盘 \TM\01\99pursey\left.php 


<script language="javascript"> 


function chkinput(form){ // 自 定义 一 个 chkinput() 函 数 
if(form.content.value==""){ // 判 断 如 果 查 询 关 键 字 文本 框 等 于 空 
alert(" 请 输入 查询 关键 字 !"); // 则 弹出 提示 信息 
form.content.select(); // 重 新 定位 焦点 
return false; // 返 回 表单 元 素 
} 
} 
</script> 


将 表单 信息 提交 到 数据 处 理 页 ， 连 接 数 据 库 文件 ， 接 收 表单 信息 ， 然 后 用 mysql_query0) 函 数 向 服 
务 器 发 送 SQL 语句 ， 检 索 与 查询 关键 字 相 匹配 的 信息 资源 。 代 码 如 下 : 
例 程 08 ”代码 位 置 ， 光盘 \TM\01\99pursey\findinfo.php 


<?php 

include("conn/conn.php"); // 连 接 数 据 库 文件 
Stype=$_POST[type]; // 获 取信 息 类 型 
$content=$_POST[content]; // 获 取 查 询 关 键 字 


$sqll=mysql_query("select * from tb_leaguerinfo where checkstate=1 and type='$type' and content like'%$content%' or 
title like'%$content%' or linkman like'%S$content%' or tel like'%S$content%0"); 

Sinfol =mysql_fetch_array($sql1); /检索 付费 的 供求 信息 

$sql=mysql_query("select * from tb_info where checkstate=1 and type='$type' and content like'%S$content%' or title 
like'%$content%' or linkman like'%S$content%' or tel like’%S$content%"); 

Sinfo=mysql_fetch_array($sql); /检索 免费 的 供求 信息 

> 
[ED 说 明 : 信息 检索 需要 从 免费 信息 表 也 _info 和 付费 信息 表 tb leaguerinfo 中 获取 数据 ， 因 此 需要 向 

MySQL 服务 器 传递 两 条 SQL 语句 。 

用 do…while 循环 语句 输出 付费 信息 与 查询 关键 字 相 匹配 的 信息 资源 ， 并 用 str_ireplace() 函 数 对 查 
询 关 键 字 实现 描 红 功 能 ， 代 码 如 下 : 

例 程 09 ”代码 位 置 : 光盘 \TM\01\99pursey\findinfo.php 
<!-- 下 面 输出 的 是 付费 信息 与 查询 关键 字 相 匹配 的 信息 -> 


Rw 
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<?php 
ot // 如 果 检索 到 了 付费 信息 
get // 则 用 do…while 循 环 语句 输出 付费 信息 
7> 


<table width="540" border="0" cellspacing="0" cellpadding="0"> 
<tr> 
<td height="26"> 
<!-- 应 用 str_ireplace0 函 数 对 查询 关键 字 进行 描 红 --> 
<!-- 对 与 查询 关键 字 所 匹配 的 信息 类 型 进行 描 红 -> 
[<?php echo str_ireplace($content,"<font color=#FF0000'>".$content."</font>",$infol[type]):;?>] nbsp; 
<!-- 对 与 查询 关键 字 所 匹配 的 信息 标题 进行 描 红 ”--> 
<?php echo str ireplace($content,"<font color=#FF0000'>".$content."</font>",$info1[title]);?>&nbsp;&nbsp; 
<!-- 对 与 查询 关键 字 所 匹配 的 发 布 时 间 进 行 描 红 -> 
<?php echo str ireplace($content,"<font color=#FF0000'>".$content."</font>",$infol[edate]);?></td> 
<tr> 
<tr> 
<td height="26">&nbsp;&nbsp; &nbsp;&nbsp; 
<!-- 对 与 查询 关键 字 所 匹配 的 信息 内 容 进行 描 红 一 > 
<?php echo str ireplace($content,"<font color=#FF0000'>".$content."</font>",$infol[content]);?></td> 
<t> 
<tr> 
<td height="26">&nbsp; 联 系 人 : 
<!-- 对 与 查询 关键 字 所 匹配 的 联系 人 进行 描 红 -> 
<?php echo str ireplace($content,"<font color=#FF0000>".$content."</font>",$infol[linkman]);?>&nbsp; 
<!-- 对 与 查询 关键 字 所 匹配 的 联系 电话 进行 描 红 -~> 
联系 电话 : <?php echo str_ireplace($content,"<font color='#FF0000>".$content."</font>",$infol[tel]);?> 


<?phi 
: So ll ); // 循 环 语句 结束 
?> 
[ED 说 明 : 免费 信息 的 输出 方式 与 付费 信息 的 基本 类 似 ， 代 码 部 分 略 ， 详 见 本 书 附 赠 光 盘 。 
免费 信息 的 输出 方式 与 付费 信息 的 基本 类 似 ， 下 面 给 出 实现 过 程 的 核心 代码 结构 。 
例 程 10 ”代码 位 置 ， 光盘 \TM\01\99pursey\findinfo.php 


<!-- 一- 一- 一-- 一 一 -一 -下 面 输出 的 是 免费 信息 与 查询 关键 字 相 匹配 的 信息 -一 -一 -一 --- -> 
<?php 
if($info){ // 如 果 检索 到 了 免费 信息 
dof / 则 用 do…while 循 环 语句 输出 付费 信息 
> 
加 // 免 费 信息 的 输出 方式 与 付费 信息 的 类 似 , 代码 略 
<?php 
} while($info=mysql_fetch_array($sql)); /do…while 循 环 语句 结束 
} //if 条 件 语句 结束 


> 


如 果 在 免费 信息 表 和 付费 信息 表 中 没有 检索 到 与 查询 关键 字 相 匹配 的 数据 ， 则 弹出 提示 信息 ， 代 


码 如 下 : 
»*45°* 多 
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例 程 11 ”代码 位 置 : 光盘 \TM\01\99pursey\findinfo.php 
<table width="540" border="0" cellspacing="0" cellpadding="0"> 


<t> 


<td align="center"> 您 检索 的 信息 资源 不 存在 ! </td> 


<t> 


</table> 


1.10 


1.10:4 


台 首 页 设计 


后 台 首 页 概述 


程序 开发 人 员 在 设计 网 站 后 台 主 页 时 ， 主 要 从 后 台 管理 人 员 对 功能 的 易 操作 实用 性 、 网 站 的 易 维 
护 性 考虑 ， 因 此 采用 了 框架 技术 。 九 九 度 供求 信息 网 后 台 首 页 主要 包含 以 下 内 容 : 


轿 图 回回 


发 布 付费 的 供求 信息 《包括 公寓 信息 、 招 聘 信息 、 求 职 信息 、 培 训 信息 、 家 教 信息 、 房 屋 信 
息 、 车 辆 信息 、 求 购 信息 、 出 售 信息 、 招 商 引资 、 寻 人 / 物 启 示 等 ) ， 以 及 付费 信息 的 浏览 、 
审核 及 删除 功能 。 

免费 信息 的 浏览 、 审 核 及 删除 功能 。 

业 广 告 信息 的 发 布 、 浏 览 、 前 台 推 荐 显示 、 删 除 功能 。 

网 站 首页 : 为 管理 员 进 入 前 台 提供 一 个 入 口 。 

退出 登录 : 注销 当前 用 户 。 


下 面 看 一 下 本 案例 中 提供 的 后 台 首 页 , 该 页 面 在 本 书 光盘 中 的 路 径 为 \TM\01\99pursey\admin\index. 
php， 如 图 1.65 所 示 。 
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图 1.65 ”供求 信息 网 站 后 台 首 页 
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1.10.2 后 台 首页 技术 分 析 


九 九 度 供求 信息 网 后 台 采 用 框架 技术 进行 页 面 布局 。 所 谓 框架 就 是 网 页 的 各 部 分 为 相互 独立 的 网 
页 ， 又 由 一 个 网 页 将 这 些 分 开 的 网 页 组 成 一 个 完整 的 网 页 ， 显 示 在 浏览 者 的 浏览 器 中 ， 重 复出 现 的 内 
容 被 固定 下 来 ， 每 次 浏览 者 发 出 对 页 面 的 请 求 时 ， 只 下 载 发 生变 化 的 框架 页 面 ， 其 他 子 页 面 保持 不 变 。 

使 用 框架 可 以 将 容器 窗口 划分 为 若干 个 子 窗口 ， 在 每 个 子 窗口 可 以 分 别 显示 不 同 的 网 页 。 首 先 在 
Dreamweaver 8 中 创建 一 个 “ 左 一 中 一 右 ”的 框架 集 ， 然 后 在 标识 @ 中 添加 “上 一 中 一 下 ”的 框架 集 ， 
最 后 在 标识 @@ 中 添加 一 个 “ 左 一 右 ” 的 框架 集 ， 从 而 完成 一 个 完整 的 后 台 框 架 。 构 建 框架 的 流程 如 
图 1.66 所 示 。 


图 1.66 网 站 后 台 框架 流程 


使 用 框架 可 以 非常 方便 地 完成 导航 工作 。 下 面 详细 介绍 框架 的 基本 结构 、 设 置 框架 集 属 性 和 框架 
属性 。 

1. 框架 网 页 的 基本 结构 

框架 网 页 通过 一 个 或 多 个 FRAMESET 和 FRAME 标记 来 定义 。 在 框架 网 页 中 ,将 FRAMESET 标 
记 置 于 HEAD 标记 之 后 ， 以 取代 BODY 标记 的 位 置 ， 当 客户 端 浏览 器 不 支持 框架 网 页 时 ， 还 可 以 使 用 
NOFRAMES 标记 给 出 框架 不 能 被 显示 时 的 蔡 换 内 容 。 框 架 网 页 的 基本 结构 可 以 表示 如 下 : 


<html> 
.47。 多 
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<head> 
<title> 基 本 框架 页 </title> 
</head> 
<frameset> 

<frame> 

<frame> 
</frameset> 
<noframes> 


<body> 
对 不 起 ! 您 的 浏览 器 不 支持 框架 页 面 的 显示 ! 
</body> 

</noframes> 

</html> 


2. 设置 框架 集 的 属性 
框架 集 包含 如 何 组 织 各 个 框架 的 信息 , 可 以 通过 FRAMESET 标记 来 定义 。 框 架 是 按照 行 和 列 来 组 
织 的 ， 可 以 使 用 FRAMESET 标记 的 下 列 属性 对 框架 的 结构 进行 设置 。 
(1) 左右 分 割 窗口 属性 COLS 
在 水 平方 向 上 将 浏览 器 分 割 成 多 个 窗口 ， 可 以 通过 框架 的 左右 分 割 窗 口 属性 COLS 实现 。 其 语法 
格式 如 下 : 
<frameset cols="value,value,..."> 
<frame> 
<frame> 
</frameset> 
属性 说 明 如 下 : 
value: 用 于 指定 各 个 框架 的 列 宽 ， 取 值 有 像素 、 百 分 比 〈%) 和 相对 尺寸 *) 3 种 形式 。 
例如 ， 若 要 通过 框架 将 浏览 器 窗口 划分 为 3 列 ， 其 中 第 1 列 占 浏览 器 窗口 宽度 的 20%， 第 2 列 为 
120 像素 ， 第 3 列 为 浏览 器 窗口 的 剩余 部 分 的 框架 ， 代 码 如 下 : 
<frameset cols="20%,120,*" > 
<frame> 


<frame> 
</frameset> 


对、 技巧 : 如 果 将 COLS 属性 设置 为 “*，*，*” ， 则 表示 将 窗口 划分 成 3 个 等 宽 的 框架 ; 如 果 将 COLS 
属性 设置 为 “*，2*，3*”， 则 表示 左边 的 框架 占 窗口 宽度 的 116， 中 间 的 框架 占 窗口 宽度 
的 1/3， 右 边 的 框架 占 窗口 宽度 的 1/2。 


(2) 上 下 分 割 窗口 属性 ROWS 
在 垂直 方向 上 将 浏览 器 分 割 成 多 个 窗口 ， 可 以 通过 框架 的 上 下 分 割 窗口 属性 ROWS 实现 。 其 语法 
格式 如 下 : 
<frameset Tows="value,value, 本 
<frame> 
<frame> 
</frameset> 


。48 。 
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属性 说 明 如 下 : 

value: 用 于 指定 各 个 框架 的 行 高 ， 取 值 有 像素 、 百 分 比 〈%) 和 相对 尺寸 (*) 3 种 形式 ， 设 置 方 
法 与 COLS 属性 类 似 。 例 如 ， 者 要 通过 框架 将 浏览 器 窗口 划分 为 3 行 ， 其 中 的 第 1 行 占 浏览 器 窗口 宽 
度 的 20%， 第 2 行为 120 像素 ， 第 3 行为 浏览 器 窗口 的 剩余 部 分 的 框架 。 其 代码 如 下 : 


<frameset rows="20%,120,*"> 
<frame> 


(3) 框架 边框 显示 属性 FRAMEBORDER 

该 属性 用 于 指定 框架 周围 是 否 显示 边框 ， 取 值 为 1 (显示 边框 ， 默 认 值 ) 或 0 (不 显示 边框 〉。 
(4) FRAMESPACING 

该 属性 用 于 指定 框架 之 间 的 间隔 ， 以 像素 为 单位 。 如 果 不 设置 该 属性 ， 则 框架 之 间 没有 间隔 。 
(5) 指定 边框 宽度 属性 BORDER 

该 属性 用 于 指定 边框 的 宽度 ， 只 有 FRAMEBORDER 属性 为 1 时 有 效 。 

3. 设置 框架 的 属性 

使 用 FRAME 标记 可 以 设置 框架 的 属性 ， 包 括 框架 的 名 称 、 框 架 是 否 包 含 滚动 条 以 及 在 框架 中 显 

示 的 网 页 等 。 其 语法 格式 如 下 : 
<frame name=" 框 架 名 称 " src=" 文 件 " frameborder=" 数 值 " scrolling=" 值 " [noresize] > 


属性 说 明 如 下 : 

name: 指定 框架 的 名 称 。 

src: 指定 在 框架 中 显示 的 网 页 文件 (包括 HTML、ASP 等 网 页 文件 ) 。 

frameborder: 指定 框架 周围 是 否 显示 边框 ， 取 值 为 1 (显示 ) 或 0 (不 显示 ) 。 默 认 值 为 1。 
scrolling: 指定 框架 是 否 包 含 滚动 条 。 如 果 将 该 属性 设置 为 yes， 则 框架 包含 滚动 条 若 将 该 
属性 设置 为 no， 则 框架 不 包含 滚动 条 ; 如 果 将 该 属性 设置 为 auto， 则 在 需要 时 包含 滚动 条 。 
noresize: 可 选 属性 ， 若 指定 了 该 属性 ， 则 不 能 调整 框架 的 大 小 。 


图 图 因 加 


加 


1.10.3 后台 首页 的 实现 过 程 


根据 以 上 两 节 的 页 面 概述 及 实现 技术 分 析 ， 需 要 分 别 创建 实现 各 区 域 的 PHP 文件 ， 如 实现 Banner 
“ 告 栏 的 top.php、 功 能 导航 栏 的 lef:php、 内 容 显示 区 的 main.php 和 页 尾 文件 bottom.php 等 。 下 面 给 
出 实现 该 系统 后 台 框 架 布局 的 完整 代码 。 

例 程 12 ”代码 位 置 : 光盘 \TM\01\99pursey\admin\index.php 
<frameset rows="*" cols="1*,1005,1*" framespacing="0" frameborder="NO" border="0"> 

<frame src="blank.php" name="left" scrolling=" NO" noresize> <!-- 设 置 空 框架 页 --> 

<frameset rows="1005,*" cols="*" framespacing="0" frameborder="NO" border="0"> 

<frameset rows="94,*,190" cols="*" framespacing="0" frameborder="NO" border="0"> 


<frame src="top.php" name="topFrame" scrolling="NO" noresize> 
<frameset rows="*" cols="229,*" framespacing="0" frameborder="NO" border="0"> 


A 
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<frame src="left.php" name="leftFrame" scrolling="NO" noresize> 
<frame src="main.php" name="mainFrame" scrolling="NO" noresize> 
</frameset> 
<frame src="bottom.php" name="bottomFrame" scrolling="NO" noresize> 
</frameset> 
<frame src="blank.php" name="right" scrolling="NO" noresize> 
</frameset> 
<frame sre="blank.php"></frameset> <!-- 设 置 空 框架 页 --> 
<noframes><body> 
</body></noframes> 
全 注意 : 在 建设 Web 网 站 时 ， 如 何 让 不 同 分 辩 率 的 用 户 都 能 看 到 网 页 的 最 佳 效果 是 程序 员 在 设计 之 
初 所 要 考虑 的 首要 问题 .为 了 使 屏蔽 的 分 辨 率 在 大 于 1024 x 768 像素 的 设置 时 仍然 处 于 居中 
显示 ， 只 需要 在 设置 框架 布局 时 ， 在 主 框架 两 侧 各 设置 一 个 宽度 相同 的 blank.php 空 页 即 可 。 


1.11 付费 供求 信息 发 布 模块 设计 


1.11.1 付费 供求 信息 发 布 模块 概述 


付费 供求 信息 的 发 布 提供 对 象 为 供求 信息 用 户 ， 是 供求 信息 网 站 非常 重要 的 功能 ， 也 是 供求 信息 
网 站 的 乔 利 点 。 企 业 或 用 户 可 以 根据 自身 需要 对 供求 信息 先进 行 付费 ， 付 费 后 由 管理 员 在 后 台 将 供求 
ee ig te gre ge en ne tg ie 培训 信息 、 公 寓 信 息 、 
家 教 信息 、 车 辆 信息 、 物 品 求购 、 物 品 出 售 、 求 竞 出 竞 ， 寻 求 合 作 、 广告 等 类 型 供求 信息 ) 。 供 
求 信息 成 功 发 布 后 ， 管 理 员 需要 在 后 台 Www was 则 显示 在 前 台 
相应 的 信息 类 别 网 页 中 。 付 费 供求 信息 发 布 的 流程 如 图 1.67 所 示 。 


人 


管理 员 


发 布 的 信息 


在 前 台 展示 
发 布 的 信息 


1.67 ”付费 供求 信息 发 布 流程 图 
\ 。50 。 


第 1 章 九 九 度 供求 信息 网 (Apache+PHP+phpMyAdmin+MySQL 5.0 实现 ) 


1.11.2 ”付费 供求 信息 发 布 模块 技术 分 析 


付费 供求 信息 与 免费 供求 信息 不 同 的 是 ， 付 费 供求 信息 不 仅 需 要 收取 一 定 的 费用 ， 而 且 还 需要 一 
定 的 时 间 限制 ， 例 如 ， 网 站 要 求 一 个 月 ( 按 30 天 计算 ) 每 条 信息 交 10 元 的 信息 费 ， 如 果 用 户 交纳 20 
元 ,那么 信息 显示 的 天 数 就 是 60 天 。 在 前 台 进 行 显示 时 ， 不 需要 管理 员 进行 手动 管理 ， 而 是 通过 程序 
直接 计算 出 信息 显示 的 截止 时 间 。 

信息 显示 的 截止 时 间 =“ 系 统 当前 日 期 ”+“ 信 息 的 有 效 天 数 〈 与 用 户 交纳 的 信息 费 相 关 ) ”。 

自动 计算 信息 显示 的 截止 时 间 的 具体 代码 如 下 : 


$days=$_POST[days]; // 通 过 表单 传 值 获取 信息 显示 的 天 数 
$showday=date("Y-m-d",(time()+3600*24*$days)); // 信 息 显示 的 截止 时 间 
[0 说 明 : 信息 的 有 效 天 数 与 用 户 交纳 的 信息 费 相 关 ， 交 费 不 通过 本 程序 完成 ， 因 此 ， 信 息 的 有 效 天 
数 需 要 管理 员 手动 添加 。 


1.11.3 ”付费 供求 信息 发 布 模块 的 实现 过 程 


国 ”付费 供求 信息 发 布 使 用 的 数据 表 : tb_leaguerinfo 

用 户 通过 单 击 页 面 导航 区 的 “付费 信息 ” 超 链 接 ， 进 入 付费 信息 发 布 页 面 ， 如 图 1.68 所 示 。 填 写 
真实 有 效 的 付费 信息 ， 单 击 “ 发 布 信 息 ” 按 钮 ， 程 序 会 先 验 证 用 户 输 入 的 信息 ， 若 验证 失败 ， 则 返回 
信息 发 布 页 面 ， 进 行 相应 提示 。 若 验证 成 功 ， 则 向 数据 库 中 插入 记录 ， 完 成 付费 信息 的 发 布 操作 。 


和 R42 下 后 写 则 后 全 量 理 系统 


ToDT Go ol 
A WER EES: 


加 次 现在 的 位 置 : 九 大 度 供求 项 和 网 后 管理 系统 


旧 免费 信息 显示 方式 
奖 而 要 所 一 一 一 一 一 
CE 审核 未定 众人 全 部 
信息 奖 唱 : 太子 芍 信 8- ”到 隐 是 否 付 费 
人 包头 别 : [来 了 信息 。 了 涩 条 入 息 标题 : 随 符 双 ) 基 基 一 
时 付 费 信 息 显 示 方 式 | 
会 和 乐 、 王 后、 站 语 ， 才 三 和 以 上 幼 雪 引 有 者 区 ， 介 纪 
冯 付 和 所 帮 一 一 一 一 一 一 
中 忆 付费 6 未 付费 个 全 部 信息 上 内容: 
| 目 
昌 企业 广告 显示 方式 信 系 人 : 辆 2 
闪失 基态 一 一 一 一 一 一 基 系 电话 : 166500 
EO A 天 
各 有 
发 布 信息 


才 放 度 世 地 信息 网 we。 hell0_ eon 白 权 所 丰 


1.68 ”付费 供求 信息 发 布 页 面 运行 结果 
。51 。 乡 
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在 左 侧 框架 left.php 页 中 ， 添 加 “付费 信息 ”图 像 域 及 表单 ， 代 码 如 下 : 
例 程 13 ”代码 位 置 ， 光盘 \TM\01\99pursey\admin\left.php 


<form name="form1" method="post" action="release_content.php" target="mainFrame"> 
<input name="imageField" type="image" class="inputl" src="images/btn fufei.gif" width="210" height="39" 


border="0"> 


</form> 


单 击 “付费 信息 ”按钮 ， 将 信息 页 release_content.php 中 的 内 容 显 示 在 框架 显示 页 mainFrame 中 。 


付费 供求 信息 发 布 页 面 主要 用 于 发 布 付费 的 供求 信息 , 该 页 面 中 所 涉及 到 的 重要 表单 元 素 如 表 1.9 
所 示 。 
表 1.9 付费 供求 信息 页 面 所 涉及 的 重要 表单 元 素 
名 称 | 元 素 类 型 重要 属性 含义 

forml form method="post" action="release_ok.php" 表单 

<select name="type"> 

<option value=" 招 聘 信息 ">- 招 聘 信息 -</option> 
be it < value=" 求 职 信息 " selected>- 求 职 信息 -</option> 信息 类 型 

<option value=" 寻 人 / 物 启 示 ">- 寻 人 / 物 启示 -</option> 

</select> 

flag checkbox class="inputl" value="1" checked “是 否 付 费 ” 复 选 框 
title text size="50" 信息 标题 
content textarea Cols="55" rows="8" 信息 内 容 
linkman text size="30" 联系 人 
tel text size="30" 联系 电话 
days text 有 效 天 数 
imageField image Src="images/fa jpg" onClick="retum checkform(form);" “发 布 信息 ”按钮 


在 付费 信息 发 布 页 面 选择 要 发 布 的 信息 类 型 后 ， 填 写真 实 有 效 的 供求 信息 。 为 了 避免 用 户 添 加 空 
信息 ， 在 单 击 “ 发 布 信息 ”按钮 时 ， 应 用 JavaScript 脚本 自 定 义 一 个 checkform() 函 数 ， 验 证 提交 的 表 
单 各 元 素 是 否 为 空 值 ， 如 果 为 空 ， 则 弹出 提示 信息 ， 并 将 焦点 定位 到 为 空 值 的 表单 元 素 。checkformO 
函数 的 代码 部 分 与 例 程 04 相同 ， 这 里 不 再 歼 述 。 


提交 表单 信息 到 数据 处 理 页 ， 应 用 insert…into 语句 向 免费 供求 信息 表 中 添加 
添加 成 功 ， 则 弹出 成 功 的 信息 提示 ; 否则 弹出 失败 的 提示 信息 。 代 码 如 下 : 
例 程 14 ”代码 位 置 : 光盘 \TM\01\99pursey\admin\release_ok.php 


<2php 


include("../conn/conn.php"); 


$type=$_POST[type]; 
Sflag=$_POST[flag]; 
$title=$_ POST[title]; 


$content=$_POST[content]; 


/连接 数据 库 文件 
/获取 信息 类 型 
/获取 付款 状态 
/获取 信息 标题 
/ 苇 取 信息 内 容 


Slinkman=$_POST[linkman]; /获取 联系 人 
\ 。52 。 


供求 信息 。 如 果 信 息 
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$days=$_POST[days]; // 获 取 发 布 时间 
S$tel=$_POST[tel]; /获取 联系 电话 
$sdate=date("Y-m-d"); // 当 前 系统 时 间 

@ $showday=date("Y-m-d",(timeQ+3600*24*Sdays)); // 获 取信 息 的 有 效 时 间 


$sql=mysql query("insert into tb_leaguerinfo(type,title,content,linkman,tel,sdate,showday,checkstate) 
values('$type','$title','$content','$linkman','$tel','$sdate','$showday’,$flag)"); // 将 付费 的 供求 信息 添加 到 数据 表 中 
if($sqD){ // 如 果 添加 操作 成 功 ， 则 弹出 提示 信息 
© echo "<script>alert(' 信 息 发 布 成 功 ! ); parent.mainFrame.location.href='release_content.php';</script>"; 
jelsef /如 果 添 加 操作 失败 ， 则 弹出 提示 信息 
echo "<script>alert(' 信 息 发 布 失败 ! ");history.back();</script>"; 
} 
> 


Ah 代码 贴 十 

@ date("Y-m-d",(time()+3600*24*$days)): 信息 的 有 效 时 间 = 当 前 期 日 期 + 付费 期 限 。 应 用 time() 函 数 获取 当前 日 期 
时 间 稚 ， 付 费 期 限 的 时 间 稚 等 于 3600 秒 x 24 小 时 x 指定 天 数 ， 并 通过 date() 函 数 格式 化 为 指定 日 期 格式 。 

@ parentmainFrame.location .hre 人 release_content.php': 刷新 父 框 架 页 release_content.php 中 的 信息 。 


1.12 ”付费 信息 管理 模块 设计 


1.12.1 付费 信息 管理 模块 概述 


付费 信息 管理 模块 主要 包括 查看 图 书 列表 、 付 费 信息 审核 和 付费 信息 删除 等 3 个 功能 。 付 费 信息 


管理 模块 的 框架 如 图 1.69 所 示 。 


付费 信息 管理 
LD Y 
付费 信息 列表 付费 信息 审核 | [rms | 
VY 
是 否 通过 审核 
否 是 


人 结束 ) 在 前 台 显示 


图 1.69 付费 信息 管理 模块 的 框架 图 
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1.12.2 ”付费 信息 管理 模块 技术 分 析 


付费 信息 管理 页 面 在 实现 信息 审核 及 删除 的 功能 时 应 用 到 了 UPDATE 更 新 语句 和 DELETE 删 除 语 
句 。 下 面 对 这 两 个 语句 进行 详细 的 讲解 。 
1. UPDATE 语句 


UPDATE 语句 用 来 改变 单行 上 的 一 列 或 多 列 的 值 , 或 者 改变 单个 表 中 选 定 的 一 些 行 上 的 多 个 列 值 。 
UPDATE 语句 的 语法 如 下 : 

UPDATE<table name | view name> 

SET <column name>=<expression> 


[....,<last column name>=<last expression>] 
[WHERE<search_condition>] 


UPDATE 语句 的 参数 说 明 如 表 1.10 所 示 。 


表 1.10 UPDATE 语句 的 参数 说 明 
参 数 说 了 明 
需要 更 新 的 表 的 名 称 。 如 果 该 表 不 在 当前 服务 器 或 数据 库 中 ， 或 不 为 当前 用 户 所 有 ， 这 个 名 称 
可 用 链接 服务 器 、 数 据 库 和 所 有 者 名 称 来 限定 
要 更 新 的 视图 的 名 称 。 通过 view_name 来 引用 的 视图 必须 是 可 更 新 的 。 用 UPDATE 语句 进行 
的 修改 ， 至 多 只 能 影响 视图 的 FROM 子 句 所 引用 的 基 表 中 的 一 个 
SET 指定 要 更 新 的 列 或 变量 名 称 的 列表 
含有 要 更 改 数据 的 列 的 名 称 。column_name 必须 驻 留 于 UPDATE 子 句 中 所 指定 的 表 或 视图 中 。 
column_name 标识 列 不 能 进行 更 新 。 如 果 指 定 了 限定 的 列 名 称 ， 限 定 符 必须 同 UPDATE 子 句 中 的 表 或 视图 
的 名 称 相 匹 配 
变量 、 字 面值 、 表 达 式 或 加 上 括号 返回 单个 值 的 subSELECT 语句 。expression 返回 的 值 将 替 
换 column_name 或 @variable 中 的 现 有 值 
指定 条 件 来 限定 所 更 新 的 行 。 根 据 所 使 用 的 WHERE 子 句 的 形式 ， 有 两 种 更 新 形式 ， 
WHERE 搜索 更 新 指定 搜索 条 件 来 限定 要 删除 的 行 
定位 更 新 使 用 CURRENT OF 子 句 指定 游标 。 更 新 操作 发 生 在 游标 的 当前 位 置 
为 要 更 新 行 指定 需 满 足 的 条 件 。 搜 索 条 件 也 可 以 是 联接 所 基于 的 条 件 。 对 搜索 条 件 中 可 以 包含 
的 谓词 数量 没有 限制 


table_name 


view_name 


expression 


<search_condition> 


全 注意 : 一 定 要 确保 不 要 忽略 WHERE 子 句 ， 除 非 想 要 更 新 表 中 的 所 有 行 。 

下 面 应 用 UPDATE 语句 将 指定 职员 的 工资 进行 调整 ， 例 如 ， 将 “小 璇 ”的 基本 工资 由 2600 元 修 
改 为 3000 元 。 其 SQL 语句 如 下 : 

update tab_laborage set jbgz=3000 where name=' 小 歼 ' 

2. DELETE 语句 

DELETE 语句 实现 删除 数据 记录 。DELETE 语句 的 语法 如 下 : 
。54 。 
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DELETE FROM <table name > 
[WHERE<search condition>] 


DELETE 语句 的 参数 说 明 如 表 1.11 所 示 。 
表 1.11 DELETE 语句 的 参数 说 明 


参 数 说 了 明 
可 选 的 关键 字 ， 可 用 在 DELETE 关键 字 与 目标 table_ name、view_name 或 rowset function_ 
FROM a 
limited 之 间 
table name 是 要 从 其 中 删除 行 的 表 的 名 称 


<search_ condition> | 指定 删除 行 的 限定 条 件 。 对 搜索 条 件 中 可 以 包含 的 谓词 数量 没有 限制 


下 面 应 用 DELETE 语句 删除 “职员 姓名 = 小 璇 ”的 员工 基本 信息 。 其 SQL 语句 如 下 : 
DELETE tab_staffer WHERE ygname=' 小 璇 ' 


1.12.3 ”付费 信息 显示 的 实现 过 程 


国 ”付费 信息 显示 页 面 使 用 的 数据 表 : tb_leaguerinfo 

管理 员 在 后 台 功 能 导航 区 的 付费 信息 显示 方式 栏 中 选择 相应 的 信息 类 别 ,然后 按 “ 已 付费 ”、“ 未 
付费 ”或 “全 部 ”中 的 任意 一 种 状态 对 付费 信息 进行 管理 。 例 如 ， 在 “信息 类 别 ” 下 拉 列 表 框 中 选择 
“公寓 信息 ”， 在 付费 状态 中 选中 “未 付费 ” 单 选 按钮 ， 单 击 “ 检 索 ”按钮 提交 表单 ， 程 序 将 按 指定 
条 件 显 示 出 符合 条 件 的 所 有 信息 ， 运 行 结果 如 图 1.70 所 示 。 
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本 系统 提供 了 一 组 单 选 按钮 组 成 的 “付费 状态 ”选项 组 ， 付 费 状 态 分 为 已 付费 、 未 付费 和 全 部 3 
个 选项 。 选 中 “未 付费 ” 单 选 按钮 ， 则 传递 的 值 为 “0”; 选中 “已 付费 ” 单 选 按钮 ， 则 传递 的 值 为 “1”; 
选中 “全 部 ” 单 选 按钮 ， 则 传递 的 值 为 “all”。 还 提供 了 一 个 下 拉 列 表 框 ， 供 用 户 选 择 信 息 类 别 。 将 
这 些 单 选 按钮 与 下 拉 列 表 框 都 在 一 个 表单 中 实现 ， 这 样 ， 当 单 击 “ 检 索 ” 按 钮 提交 表单 后 ， 选 择 的 状 
态 会 通过 表单 进行 传递 。 其 表单 代码 如 下 : 
例 程 15 ”代码 位 置 ， 光盘 \TM\01\99pursey\admin\left.php 
© <formname="form3" method="post" action="find_mianfei.php" target="mainFrame"> 
<tr> 
<td height="65" align="center"> 
© <fieldset style="height:60;width:210"> 
<legend> 克 审核 状态 </legend> 
<input name="state" type="radio" class="inputl" value="1"> 已 审核 
<input name="state" type="radio" class="inputl" value="0" checked> 未 审核 
<input name="state" type="radio" class="inputl" value="all"> 全 部 
</fieldset> 
</tr> 
<tr> 
<td height="34" align="center" background="images/info_d.gif"> 信 息 类 别 : 
<select name="type"> 
<option value=" 招 聘 信息 ">- 招 聘 信息 </option> 
<option value=" 求 职 信息 " selected>- 求 职 信息 </option> 


</select> 
<input type="submit" name="Submit" value=" 检 索 "> 
</td> 
</tr> 
</form> 


Ah 代码 贴 二 

@ target: 指定 链接 的 目标 窗口 ，mainFrame 为 内 容 显示 区 的 框架 名 称 。 另 外 ，target 有 4 个 选项 值 : 

_blank: 指定 将 链接 的 目标 文件 加 载 到 未 命名 的 新 浏览 器 窗口 中 。 

_parent: 指定 将 链接 的 目标 文件 加 载 到 包含 链接 的 父 框架 页 或 窗口 中 ， 如 果 包 含 链接 的 框 不 

是 嵌 套 的 ， 则 链接 的 目标 文件 加 载 到 整个 浏览 器 窗口 中 。 

_self: 指定 将 链接 的 目标 文件 加 载 到 链接 所 在 的 同一 框架 或 窗口 中 。 

_top: 指定 将 链接 的 目标 文件 加 载 到 整个 浏览 器 窗口 中 ， 并 由 此 删除 所 有 框架 。 

@ <fieldset><legend>...</legend></fieldset> 标 签 : 在 字符 集 包含 的 文本 和 其 他 元 素 外 面 绘制 一 个 方 框 。 该 元 素 是 块 元 
素 ， 必 须 成 对 出 现 。 需 要 注意 的 是 ，fieldset 必须 用 在 form 表单 里 ， 一 个 表单 可 以 有 多 个 <fieldsef>…</fieldset>， 每 对 
<fieldset>.…</fieldset> 为 一 组 ， 每 组 的 内 容 描述 使 用 <legend> 设 置 标题 名 称 . 


提交 表单 信息 到 find_mianfei.php 页 ,程序 将 按 管 理 员 选择 的 指定 条 件 显示 出 符合 条 件 的 所 有 信息 。 
如 果 管 理 员 选 中 “全 部 ” 单 选 按钮 ， 那 么 系统 的 代码 如 下 : 
例 程 16 ”代码 位 置 ， 光盘 \TM\01\99pursey\admin\find_fufei.php 


<?php 
include("../conn/conn.php"); // 连 接 数 据 库 文件 


S= 
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$state=$_POST[payfor]; // 获 取 管 理 员 选择 的 付费 状态 
$type=$_POST[select]; // 获 取 管 理 员 选 择 的 信息 类 别 


/如 果 管 理 员 选择 的 付费 状态 为 “全 部 ”， 则 查询 管理 员 指定 信息 类 别 下 的 所 有 付费 信息 ， 并 按 id 降序 排列 
if($state=="all"){ 
$sql=mysql query("select * from tb leaguerinfo where type='$type' order by id"); 


elsef 
/如 果 管 理 员 选择 的 付费 状态 为 “已 付费 ”或 “未 付费 ”状态 ， 则 按 管 理 员 指 定 的 条 件 进 行 查询 ， 并 按 id 降 序 排列 
$sql=mysql_query("select * from tb leaguerinfo where type=$type' and checkstate=$state order by id"); 


} 
S$info=mysql_fetch_array($sql); // 执 行 SQL 语 句 
> 
人 // 省 略 供求 信息 标题 的 HTML 代 码 部 分 
<?php 
if($info){ // 如 果 检索 到 了 查询 记录 
dof // 应 用 do…while 循 环 语句 输出 付费 信息 
if($info[checkstate]==1){ // 如 果 付 费 状态 的 值 为 1 
$state1=" 已 付费 "; // 则 将 “已 付费 ” 赋 给 变量 $state1 
jelsef // 如 果 付 费 状态 的 值 为 0 
$state1=" 未 付费 "; // 则 将 “未 付费 ” 赋 给 变量 $statel 
< 输出 指定 符合 查询 条 件 的 付费 信息 --------------------------------- 一 > 


<tr bgcolor="#FFFFFF"> 

<td>&nbsp;<?php echo $infoltitle];?></td> 

<td width="204">&nbsp;<?php echo $info[content];?></td> 

<td>&nbsp;<?php echo $infollinkman]:?></td> 

<td>&nbsp;<?php echo $infoltel];?></td> 

<td>&nbsp;<?php echo $info[sdate]:?></td> 

<td>&nbsp;<?php echo $info[showday]:2></td> 

<td align="center" class="stylel1"><?php echo $statel;?></td> 

<td ali center" bgcolor="#FFFFFF"> 
<a href="statefu_ok.php?id=<?php echo $info[id];?>&type=<?php echo $type;?>&state=<?php echo $state;?>"> 审 核 </a> 
/<a href="fudel_ok.php?id=<?php echo S$info[id];?>&type=<?php echo $type;?>&state=<?php echo $state;?>"> 有 删除 </a> 


1 和 
<?php 
}while($info=mysql_fetch_array($sql); /do…while 循 环 语句 结束 
// 放 条 件 语句 结束 
// 如 果 未 检索 到 与 管理 员 指 定 条 件 相 匹配 的 记录 ， 则 输出 相关 的 提示 信息 
elsef 
?> 


<tr align="center" bgcolor="#FFFFFF"> 
<td colspan="8"> 对 不 起 ， 您 检索 的 信息 不 存在 ! </td> 
</tr> 
<?php 
} 


和 


村 
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上 说 明 : 上 面 代码 中 省 咯 了 分 页 显示 的 代码 的 部 分 ， 限 于 篇 幅 ， 参 见 本 书 附 赠 光 盘 。 
1.12.4 ”付费 信息 审核 的 实现 过 程 


国 ” 付 费 信 息 审核 使 用 的 数据 表 : tb_leaguerinfo 
经 过 审核 的 信息 说 明 该 信息 为 已 付款 信息 。 如 果 企 业 或 个 人 用 户 已 登录 供求 信息 但 未 直接 付费 ， 
需要 后 期 付款 ,那么 必须 进行 付款 ,同时 管理 员 进 行 审核 , 经 过 审核 的 信息 即 可 在 前 台 进行 显示 。“ 审 
核 ” 超 链接 的 代码 如 下 : 
例 程 17 ”代码 位 置 ， 光盘 \TM\01\99pursey\admin\find_fufei.php 
<a href="statefu_ok.php?id=<?php echo $info[id];?>&type=<?php echo $type;?>&state=<?php echo $state;?>"> 审 核 </a> 
管理 员 单 击 对 应 主题 信息 后 面 的 “审核 ” 超 链 接 ， 将 信息 所 对 应 的 id 值 、 信 息 类 型 及 审核 状态 传 
递 到 数据 处 理 页 statefu_ok.php， 用 UPDATE 语句 将 付费 状态 设置 为 1， 说 明 该 信息 已 经 付款 ， 数 据 处 
理 页 的 代码 如 下 : 
例 程 18 ”代码 位 置 : 光盘 \TM\01\99pursey\admin\statefu_ok.php 


<2php 
include("../conn/conn.php"); // 连 接 数 据 库 文件 
$id=$_GET[id]; // 获 取信 息 id 的 值 
$type=$_GET[type]; /获取 信息 类 型 
S$state=$_GET[state]; /获取 信息 付费 状态 
© $sql=mysql_query("update tb_leaguerinfo set checkstate=] where id=$id"); /更 新 对 应 付费 信息 的 状态 为 已 付款 
ifS$sql){ /如 果 更 新 操作 成 功 
@ echo "<script>alert(' 该 信息 已 经 通过 审核 ! 
");window.location.href='find_fufei.php?type=Stype&state=Sstate';</script>"; // 弹 出 操作 成 功 提示 信息 
| 
elsef // 如 果 更 新 操作 失败 
echo "<script>alert(' 该 信息 审核 操作 失败 ! ");history.back();</script>"，”// 弹 出 操作 失败 信息 
} 
> 
Ah 代码 贴 十 


@ update.…set: 用 来 修改 指定 表 中 的 数据 。UPDATE 语句 的 使 用 方法 参见 1.12.2 节 。 

@ type=$type&state=$state: 将 变量 type 与 state 的 值 重新 传 到 find_fufei.php 页 ， 目 的 是 为 了 使 find_ 
fufeiphp 页 中 的 $type 和 $state 变量 重新 获得 信息 类 型 和 付费 状态 值 (管理 员 选 择 的 检索 条 件 ) ， 从 而 返回 到 付费 信息 管 
理 页 ， 并 更 新 数据 信息 。 如 果 数 据 处 理 页 不 对 这 两 个 变量 进行 传 值 ， 那 么 在 返回 到 付费 信息 管理 页 find_fufei.php 页 时 
将 会 因为 检索 不 到 变量 的 值 而 出 错 。 


1.12.5 ”付费 信息 删除 的 实现 过 程 


国 ”付费 信息 删除 使 用 的 数据 表 : tb_leaguerinfo 
付费 信息 管理 页 中 “删除 ” 超 链接 的 代码 如 下 : 


S> 
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例 程 19 ”代码 位 置 ， 光盘 \TM\01\99pursey\admin\find_fufei.php 
<a href="fudel_ok.php?id=<?php echo $info[id]:?>&type=<?php echo Stype:?>&state=<2php echo $state;?>"> 删 除 </a> 
管理 员 单 击 对 应 主题 信息 后 面 的 “审核 ” 超 链接 ， 将 信息 所 对 应 的 id 值 、 信 息 类 型 及 审核 状态 伟 
递 到 数据 处 理 页 fdel_ok.php， 用 DELETE 语句 将 id 指定 的 供求 信息 删除 ， 数 据 处 理 页 的 代码 如 下 : 
例 程 20 ”代码 位 置 ， 光盘 \TM\01\99pursey\admin\fudel_ok.php 


<?php 

include("../conn/conn.php"); 1/ 连接 数据 库 文件 

$id=$_GET[id]; // 获 取信 息 id 的 值 

S$type=$_GET[type]; 1/ 获取 信息 类 型 

$state=$_GET[state]; // 获 取信 息 付费 状态 
$sql=mysql_query("delete from tb_leaguerinfo where id=$id"); /删除 对 应 的 供求 信息 

if($sqD{ // 如 果 删 除 操作 成 功 ， 则 弹出 提示 信息 


echo "<script>alert(' 该 信息 已 经 删除 ! ");window.location.href='find_fufei.php?type=Stype&state=$state';</script>"; 


} 
elsef // 如 果 删 除 操作 失败 ， 则 弹出 提示 信息 


echo "<script>alert( 该 信息 删除 操作 失败 ! "):history.back0;</script>"; 


上 
?> 


全 注意 : 在 删除 数据 后 ， 仍 需要 将 变量 Stype 和 S$state 的 值 重新 传递 给 付费 信息 管理 页 find_fufei.php 
页 ， 目 的 是 返回 到 付费 信息 管理 页 ， 查 看 执行 删除 操作 后 的 状态 。 


1.12.6 单元 测试 


在 开发 完 管理 员 模块 后 ， 对 该 模块 进行 单元 测试 。 当 管理 员 对 付费 供求 信息 进行 审核 后 ， 审 核 操 
作成 功 了 ， 但 却 弹出 如 图 1.71 所 示 的 错误 提示 。 


1 人 没有 检索 到 数据 信息 的 错误 提示 


JUuUUDUcai 


fetch_ arrayO: supplied argument is not a valid MySQL result resource in 
ervvwwwATEV99Pursey\adnin\find_fufei-php on line 16 


加 免费 信息 显示 方式 
[ 太 审核 关 着 一 — 
| C 已 审核 全 未 审核 个 全 部 
| 

信息 类 别 : [ 求 取 信息 ” 司 | 国 漳 | 当前 信息 类 别 : 


加 付费 信息 显示 方式 信息 标题 信息 内 容 联系 人 联系 电话 。 发 布 日 期 “截止 日 了 
对 不 起 ， 悠 检索 的 信息 不 存在 


MySQL result resource in 


[ 女 付费 状态 一 一 一 一 国 
个 已 付费 @@ 未 付费 个 全 部 


信息 类 别 为 空 ， 说 明 没 有 获取 到 值 


信息 类 别 : [- 公 训 信息 ” 司 | [ 瑟 天 | 


图 1.71 审核 付费 供求 信息 的 错误 提示 
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在 图 1.71 中 的 错误 提示 中 可 以 看 出 ， 在 付费 信息 管理 页 的 第 16 行 和 第 17 行 出 现 问题 。 下 面 看 一 
下 出 现 问题 的 这 两 行 代码 : 


if($state=="all"){ // 如 果 管 理 员 选择 的 付费 状态 为 “全 部 ”， 则 执行 下 面 的 SQL 语 句 
$sqll=mysql query("select count(*) as total from tb leaguerinfo where type='$type' order by id"); 
jelsef // 否 则 ， 执 行 下 面 的 SQL 语句 


S$sqll=mysql query("select count(*) as total from tb leaguerinfo where type='$type' and checkstate=$state order by 
id"); 


/本 机 宁 宁 于 下 于 永宁 于 末末 于 宁 训 永宁 于 宇宙 于 本 训 本 本人 ] G 全 人 人 3 本 本 本 本 本 机 本 机 机 本 机 机 可 机 可 机 机 可 机 本 可 可可 可 于 环球 人 


$minfo=mysql fetch array($sq11); 
ai 洒 17 行 代码 站 本 本 本 本 机 本 市 本 本 机 机 本 可 训 刺 训 可 可 刺 可 可 训 可 事 事 事 可 


S$total=$minfo[total]; 

从 代码 中 可 以 看 出 ，SQL 语句 的 书写 并 没有 错误 。 根 据 图 1.71 所 示 的 页 面 的 结果 ， 当 前 信息 类 别 
为 空 ， 则 说 明 管 理 员 选择 的 信息 类 别 没有 传 过 来 值 ， 由 此 可 以 看 出 ， 这 是 由 于 在 执行 审核 后 页 面 重 新 
刷新 了 ， 因 此 检索 不 到 管理 员 选 定 的 查询 条 件 值 。 

“审核 ” 超 链 接 的 源 代码 如 下 : 

例 程 21 ”代码 位 置 ， 光盘 \TM\01\99pursey\adminVfind_fufei.php 

<a href="statefu_ok.php?id=<?php echo $info[id];?>"> 审 核 </a> 
审核 处 理 页 的 源 代码 如 下 : 

例 程 22 ”代码 位 置 ， 光盘 \TM\01\99pursey\admin\statefu_ok.php 


<?php 

$id=$_GET[id]; // 获 取信 息 id 的 值 
$sql=mysql_query("update tb_leaguerinfo set checkstate=1 where id=$id"); // 更 新 对 应 付费 信息 的 状态 为 已 付款 
if$sqD){ // 如 果 更 新 操作 成 功 ， 弹 出 提示 信息 


echo "<script>alert(' 该 信息 已 经 通过 审核 ! ");window.location.href="'find_fufei.php;</script>"; 
} 
解决 该 问题 的 方法 需要 在 “审核 ” 超 链接 传 值 时 将 管理 员 选 定 的 “信息 类 型 ”和 “审核 状态 ”的 
变量 值 一 同 传递 到 数据 处 理 页 ， 当 审核 操作 完成 后 ， 再 将 “信息 类 型 ”和 “审核 状态 ”的 变量 值 重新 
传递 给 付费 信息 管理 页 find_fufei.php 即 可 。 
“审核 ” 超 链接 的 修改 后 的 代码 〈 加 粗 的 代码 部 分 为 修改 的 代码 部 分 ) 如 下 : 
例 程 23 ”代码 位 置 ， 光盘 \TM\01\99pursey\admin\find_fufei.php 


<a href="statefu_ok.php?id=<?php echo S$info[id];?>&type=<?php echo Stype;?>&state=<?php echo Sstate;?>"> 审 核 
</a> 


技巧 :在 传递 多 个 变量 时 ， 变 量 之 间 用 “&” 符 号 分 隔 。 


管理 员 单 击 对 应 主题 信息 后 面 的 “审核 ” 超 链接 ， 将 信息 所 对 应 的 id 值 、 信 息 类 型 及 审核 状态 传 
递 到 数据 处 理 页 statefu_ok.php， 在 执行 完 更 新 操作 后 ， 需 要 将 “信息 类 型 ”和 “审核 状态 ”的 变量 值 
重新 传递 到 付费 信息 管理 页 find_fufei.php， 加 粗 的 代码 部 分 为 修改 的 代码 部 分 。 


RS 
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例 程 24 ”代码 位 置 ， 光盘 \TM\01\99pursey\admin\statefu_ok.php 


<?php 
$id=$_GET[id]; // 获 取信 息 id 的 值 
Stype=$_GETI[typel; /获取 信息 类 型 
Sstate=$_GETIstate]; // 获 取信 息 付费 状态 
$sql=mysql_query("update tb_leaguerinfo set checkstate=1 where id=$id"); /更 新 对 应 付费 信息 的 状态 为 已 付款 
if($sqD{ // 如 果 更 新 操作 成 功 
echo "<script>alert(' 该 信息 已 经 通过 审核 ! 

");window location.href='find_fufei.php?type=Stype&state=S$state';</script>"; // 弹 出 操作 成 功 提示 信息 

E 


1.13 ”网 站 发 布 


开发 九 九 度 供求 信息 网 站 的 最 终 目的 是 将 其 发 布 到 Internet 上 ， 供 用 户 浏览 访问 。 

在 服务 器 上 上 载 网 站 ， 首 先 需 从 服务 商 处 申请 固定 的 IP 号 ， 然 后 再 注册 一 个 域名 ， 并 将 域名 指定 
到 该 IP 地 址 。 在 服务 器 上 安装 PHP 的 开发 环境 ， 最 后 上 载 网 站 。 

下 面 以 “ 九 九 度 供 求 信息 网 ”为 例 ， 来 讲解 在 个 人 服务 器 上 上 载 网 站 的 过 程 。 

(1) 右 击 “网 上 邻居 ”， 在 弹出 的 快捷 菜单 中 选择 “属性 ”命令 ， 打 开 “ 网 络 连接 ”对 话 框 。 

(2) 右 击 “ 本 地 连接 ”， 在 弹出 的 快捷 菜单 中 选择 “属性 ”命令 ， 打 开 “ 本 地 连接 属性 ”对 话 
框 ， 如 图 1.72 所 示 ， 在 “此 连接 使 用 下 列 选 定 的 组 件 ” 列 表 框 中 选中 “Internet 协议 〈TCP/IP) ” 复 选 
框 ， 然 后 单 击 “ 属 性 ”按钮 ， 按 服务 商 提供 的 指定 IP 设置 服务 器 的 IP 地 址 ， 如 图 1.73 所 示 。 


了 xl Internet 协议 (TCP/IP) 尾 性 了 [xj 
常规 “| 身价 验证 | 高 急 | 党 规 | 
连接 时 使 用 获取 自 TP 设置 。 否则 
[ie RD FC Feat rhe 吕 吕 证 。 
| 自动 区 得 芋 地 址 加) 
此 尝 接 使 用 下 列 选 定 的 组 件 (0) : 公 使 用 下 面 的 TP 地 址 @) ; 
回 加 是 crosoft 同 络 客户 靖 王 地 址 中 ): 221 ，8 se 可 
口 轧 网 络 载 量 平衡 子 网 掩 码 由: 255 255 9 站 相 
回 司 虱 crosoft 网 络 的 文件 和 打印 机 共享 EY 
回 生 默认 网 关 细 ); 221 .8 机， 可 
安装 四 到 二 属性 双 ) 个 目 动 区 得 而 5 服务 名 二 下 四 ) 


说 明 他 使 用 下 面 的 DRS 服务 器 地 址 到) 
到 是 默认 的 广域网 协议 。 它 提供 跨越 多 种 互联 网 络 首选 DNS 服务 器 到 ): 202 .38 .，*，， 册 
四 备用 DNS 服务 器 避 ) 202 .88 .4 


末 连接 后 在 通知 区 域 显示 图 标 由 ) 


图 1.72 “本 地 连接 属性 ”对 话 框 1.73 “Intemet 协议 CTCP/IP) 属性 ”对 话 框 
(3) 安装 PHP 的 开发 环境 ， 参 见 本 章 1.4 节 。 
(4) 将 “ 九 九 度 供求 信息 网 ”上 载 到 服务 器 指定 的 路 径 下 ， 如 图 1.74 所 示 。 
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Liglal 
| 于 


| [BS Fwppsevwwtrwiespusey EE 


EE | 大 个 | 类 型 | 修改 日 风 至 
文件 和 文件 夹 任务 3 Damn 文件 亚 2007-12-20 14:31 
已 om 文件 赤 2007-12-97 16:05 
其 它 位 置 y BD 文件 夷 2007-12-18 9:22 
已 daa 文件 天 2007-12-20 14:57 
局 maoes 文 和夫 2007-12-20 14:56 
EN 国电 文人 天 2007-12-20 10:14 
国 bottom.php 1IB PHP 文件 2007-12-4916:17 
下 cphp 148 PHP 文件 2007-12-17 9:24 
下 cx_niophp 5IB PHP 文件 2007-12-4610:36 
fndrfo.php lB PHP 文 件 2007-12147 16i02 
全 foster.php TB PHP 文 件 2007-12-17 9:06 
Foster_nfo,php 5IB PHP 文件 2007-12-16 10:35 


2007-12-17 9:06 


1.74 ”上载 “ 九 九 度 供求 信息 网 ”到 指定 的 路 径 下 
(5) 在 IE 浏览 器 地 址 栏 中 输入 申请 的 域名 ， 发 布 的 网 站 运行 结果 如 图 1.75 所 示 。 


【全 富 伟 息 上 高 本 话 女 了 公 宫 


位 于 市 中 心 。4 玫 于 面 # 内 设 国人 网 , 五 人 间 新 购 加 准确 单 人 床 . 新 法 注 计划 。 单独 
和 ET ea 新 限 和 多 ,去 柜 ,床头柜 ， 柱 朋 +t 可 健 光 ,可 月 交房 寓 + 内 入 均 
安 前 + 专人 管理 + 是 高 突 质 白 领 女 性 的 温 作 家 同 


图 1.75 “ 九 九 度 供求 信息 网 ”发 布 后 的 运行 结果 


1.14 开发 技巧 与 难点 分 析 


1.14.1 查询 关键 字 描 红 功 能 


在 九 九 度 供求 信息 网 前 台 信息 检索 过 程 中 体现 了 方便 快捷 的 人 性 化 原则 ， 为 了 方便 浏览 者 查阅 信 
息 ， 便 于 查找 与 浏览 者 的 关键 字 相 符合 的 信息 ， 在 搜索 引擎 中 添加 描 红 功能 。 

查询 关键 字 描 红 是 指 将 查询 关键 字 以 特殊 的 颜色 、 字 号 或 字体 进行 标识 ， 这 样 可 以 使 浏览 者 快速 
找到 所 需 的 关键 字 ， 方 便 浏览 者 从 搜索 结果 中 查找 所 需 内 容 。 查 询 关 键 字 描 红 适 用 于 模糊 查询 。 下 面 
介绍 如 何 实现 查询 关键 字 描 红 。 
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本 系统 用 str_ireplace() 函 数 来 替换 查询 关键 字 ， 当 显示 所 查询 的 相关 信息 时 , 将 输出 的 关键 字 的 字 
体 蔡 换 为 红色 。 描 红 功 能 的 业务 流程 如 图 1.76 所 示 。 


从 


用 户 


设置 查询 条 件 


将 关键 字 描 红 


图 1.76 查询 关键 字 描 红 

str_ireplace() 函 数 用 于 将 某 个 指定 的 字符 串 蔡 换 为 另 一 个 指定 的 字符 串 ， 不 区 分 大 小 写 。 该 函数 的 

语法 如 下 : 
mixed str_ireplace ( mixed search, mixed replace, mixed subject [, int &count]) 

该 函数 将 所 有 在 参数 subject 中 出 现 的 参数 search 以 参数 replace 取代 ， 参 数 &count 表示 取代 字符 
串 执行 的 次 数 。 

str_ireplace() 函 数 的 参数 说 明 如 表 1.12 所 示 。 

表 1.12 str_ireplace() 函 数 的 参数 说 明 


明 
必要 参数 ， 指 定 需 要 查找 的 字符 串 


必要 参数 ， 指 定 蔡 换 的 值 
必要 参数 ， 指 定 查找 的 范围 
可 选 参数 ， 获 取 执行 蔡 换 的 数量 


全 注意 : 该 函数 在 执行 替换 的 操作 时 ， 是 不 区 分 大 小 写 的 。 如 果 需 要 对 大 小 写 加 以 区 分 ， 可 以 使 用 
str_replace() 函 数 。 


本 系统 应 用 str_ireplace() 函 数 蔡 换 查询 字符 串 为 红色 的 字符 串 ， 关 键 代 码 如 下 : 


<?php 
include("conn/conn.php"); // 连 接 数 据 库 文件 
$content=$_POST[content]; /获取 查询 关键 字 


$sqll=mysql query("select * from tb leaguerinfo where checkstate=1 and type='$type' and content like'%$content%' or 
title like'%$content%' or linkman like'%S$Scontent%' or tel like'%S$content%0"); 

$info1=mysql_fetch_array($sql1); /采用 模糊 信息 资源 查询 

/下 面 应 用 str_ireplace() 将 指定 的 查询 关键 字 用 红色 文字 替代 ， 并 输出 替换 后 的 字符 串 

echo str_ireplace($content,"<font color=#FF0000'>".$content."</font>",$infol[type]); 1/ 替换 信息 类 型 为 红色 字体 

echo str_ireplace($content,"<font color=#FF0000'>".$content."</font>",$infol[title]); // 营 换 信 息 标题 为 红色 字体 


四 
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echo str_ireplace($content,"<font color=#FF0000>".$content."</font>",$infol[edate]); 1/ 替换 发 布 时 间 为 红色 字体 
echo str_ireplace($content,"<font color='#FF0000'>".$content."</font>",$infol[content]);”// 蔡 换 信 息 内 容 为 红色 字体 
echo str_ireplace($content,"<font color=#FF0000'>".$content."</font>",$infol[linkman]); // 替 换 联系 人 为 红色 字体 
echo str_ireplace($content,"<font color=#FF0000'>".$content."</font>",$info1[tel]); /| 替换 联系 电话 为 红色 字体 
?> 


1.14.2 ”表单 数据 的 提交 方式 


获取 表单 元 素 提交 的 值 是 表单 应 用 中 最 基本 的 操作 方法 。 表 单数 据 的 传送 方法 有 get 方法 和 post 
方法 两 种 ,通过 <form> 的 method 属性 来 指定 。 下 面 来 具体 讲解 一 下 这 两 种 方法 在 实际 工作 中 的 应 用 范 
围 和 使 用 技巧 。 
1. 通过 get 方法 提交 数据 
使 用 get 方法 时 ， 表 单数 据 被 当 作 url 的 一 部 分 一 起 传 过 去 。 格 式 为 : 
http://url?namel1=valuel &name2=value2...... 
url: 表单 响应 地 址 。 例 如 ，127.0.0.1/index.php。 
name: 表单 元 素 的 名 称 。 例 如 , <input type="text" name="user">, 这 里 name 的 属性 值 就 是 user。 
通过 name 值 可 以 获取 value 的 属性 值 。 
value: 表单 元 素 的 值 。 例 如 ，<input type="text" name="user" value="mr">， 意 思 是 名 字 叫 user 


的 text 表单 元 素 的 值 为 mr。 


[ED 说明， url 和 表单 元 素 之 间 用 “2?” 隔 开 ， 而 多 个 表单 元 素 之 间 用 “&” 隔 开 ， 每 个 表单 元 素 的 格式 
都 是 “name=value”， 固 定 不 变 。 
PHP 使 用 $_GET 预定 义 变量 自动 保存 通过 get 方法 传 过 来 的 值 ， 使 用 格式 为 : 
$_GET[name] 


这 样 ， 就 可 以 直接 使 用 名 字 为 name 的 表单 元 素 的 值 了 。 


0 技巧， 有 的 PHP 版 本 中 直接 写 Sname 就 可 以 调用 表单 元 素 的 值 ， 这 和 php.ini 文件 的 配置 有 关系 ， 
定位 到 GLOBAL=ON/OFF 行 ， 如 果 值 为 ON， 就 可 以 直接 写成 Sname， 反 之 则 不 可 以 。 直 
接应 用 表单 名 称 十 分 方便 ， 但 也 存在 一 定 的 安全 隐患。 推荐 读者 关闭 GLOBAL 项 。 

下 面 来 看 一 个 使 用 文本 框 传 值 的 程序 ， 程 序 中 包含 一 个 文本 框 元 素 。 在 文本 框 中 输入 信息 ， 当 单 

击 “ 提 交 ” 按 钮 时 ， 文 本 框 内 的 信息 就 会 和 url 一 起 显示 在 地 址 栏 中 ， 代 码 如 下 : 


<form name="login" method="get" action="index.php"> 
</form> 
技巧 :get 方法 是 使 用 ul 来 进行 传 值 的 ，“ 加 入 收藏 天 ”的 功能 就 是 get 方法 的 应 用 之 一 。 想 要 


将 一 个 带 参 数 的 网 址 加 入 到 “收藏 天 ”中 ， 只 能 使 用 url， 它 可 以 脱离 表单 的 束缚 。 文 字 、 
图 片 等 都 可 以 使 用 这 种 方法 来 传 值 。 
\ 。64 。 
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2. 通过 post 方法 提交 数据 

get 方法 有 个 最 大 的 缺点 ， 就 是 它 的 信息 是 显示 在 客户 端 浏览 器 上 的 ， 这 使 用 户 的 资料 暴露 无 遗 ， 
而 且 url 本 身受 长 度 限 制 (1024KB ) , 不 能 传输 较 大 的 数据 。 这 时 可 以 选择 post 方法 。 使 用 时 , 将 <form> 
表单 中 的 属性 method 设置 成 post 即 可 。post 方法 不 依赖 url， 所 有 提交 的 信息 在 后 台 传 输 ， 不 会 显示 
在 地 址 栏 中 ， 安 全 性 高 ， 而 且 没 有 长 度 限制 。 

使 用 PHP 的 $_ POST[name] 变 量 可 以 获取 表单 元 素 的 值 ， 格 式 和 $_GET[name] 类 似 : 

$_POST[name] 

例如 ， 使 用 的 post 方法 返回 文本 框 信息 ， 代 码 如 下 : 


<form name="login" method="post" action="index.php"> 


</form> 


1.15 ”MySQL 数据库 技术 专题 


phpMyAdmin 是 众多 MySQL 图 形 化 管理 工具 中 应 用 最 广泛 的 一 种 ， 它 是 基于 PHP 语言 编写 的 ， 
该 工具 是 B/S 结构 、 基 于 Web 跨 平台 的 管理 程序 ， 并 且 支 持 简体 中 文 ， 可 以 在 官方 网 站 免费 下 载 。 安 
装 后 在 浏览 器 地 址 栏 输入 http://127.0.0.1/phpMyAdmin/ 即 可 进入 MySQL 的 管理 界面 。 

phpMyAdmin 为 Web 开发 人 员 提 供 了 类 似 于 Access、SQL Server 的 图 形 化 数据 库 操作 界面 ， 通 过 
该 管理 工具 可 以 进行 绝 大 部 分 的 MySQL 操作 ， 包 括 对 数据 库 及 数据 表 的 建立 和 维护 。 


1.15.1 创建 和 删除 数据 库 


1. 创建 数据 库 
在 phpMyAdmin 的 主 界面 中 有 两 个 文本 框 和 “创建 ”按钮 ， 首 先 在 文本 框 中 输入 数据 库 的 名 称 ， 
然后 选择 编码 , 最 后 单 击 “ 创建 ?按钮 , 这 样 新 的 数据 库 就 可 以 被 创建 成 .例如 创建 一 个 名 称 为 db_pursey 
的 数据 库 ， 首先 在 文本 框 中 输入 db_pursey, 之 后 在 下 拉 列 表 框 中 找到 要 使 用 的 编码 ,在 Windows 下 一 
般 选择 gb2312_chinese_ci， 如 图 1.77 所 示 。 
习 localhost 
中 服务 器 版 本 : 50.24a-community-ntiog 


[ema » Protocol version: 10 
加 服务 器 : localhost via TCPIP 
， 用 户 ; root@localhost 
数据 库 国 wysQL 字符 集 UTF-8 Unicode (utf8) 
由 二 贺 WysaQL 连接 校对 [957312_chinese cl 司 @ 
建 一 个 新 的 数据 | 
请 掺 数据 放 a < 


(pry ) (Ce 习 胸 时 


事 显 示 MySQL 的 运行 信息 选择 编码 格式 
国 显示 MySQL 的 系统 变量 加 园 式 


1.77 ” phpMyAdmin 管理 界面 
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最 后 单 击 “创建 ” 按 扭 ， 这 样 名 为 db_pursey 的 数据 库 就 被 创建 成 功 ， 执 行 结果 如 图 1.78 所 示 。 
可 加 服务 器 :localhost 局 数据 库 : db_pursey 


_ 卫 结构 于 Sal 万 着 过 局 查询 部 导 出 项 mporl 狼 所 作坊 权限 ”加 弄 了 
phpldyAdmin 
Mi 与 当前 数据 库 和 表 相 关 的 操作 


中 加 四 广 SQL 查询 
| CREATE DATABASE ‘db_pursey 


Grn 


db pursey (0) 数据 库 中 没有 表 。 输入 新 建 表 名 
广 罚 在 数据 库 db_p 坟 sey 中 创建 一 个 新 表 
区 可 Sa Nmberorat( 下 


[waver 上 


图 1.78 数据 库 的 建立 

该 数据 库 名 称 出 现在 左 侧 导 航 栏 的 数据 库 下 拉 菜 单 中 ， 选 择 这 个 数据 库 ， 在 右 侧 界面 中 可 以 对 该 
数据 库 进行 操作 ， 如 结构 、SQL、 导 出 、 搜 索 、 查 询 、 删 除 等 ， 单 击 相应 的 按钮 即 可 进入 相应 的 操作 
界面 。 但 是 在 创建 数据 库 还 没有 创建 数据 表 的 情况 下 ， 只 能 够 执行 结构 、SQL 和 删除 3 项 操作 ， 其 他 
操作 不 可 以 执行 。 

2. 删除 数据 库 

要 删除 某 个 数据 库 ， 首 先 在 左 侧 的 下 拉 菜 单 中 选择 该 数据 库 ， 然 后 单 击 右 侧 界面 中 的 “删除 ” 按 
钮 即 可 。 


1.15.2 ”创建 和 删除 数据 表 


针对 表 级 操作 是 在 选 定 了 数据 库 的 情况 下 进行 的 , 即 表 级 操作 的 前 题 是 用 户 必须 选择 一 个 数据 库 ， 
在 该 数据 库 中 进行 表 的 建立 和 维护 。 

1. 创建 数据 表 

创建 数据 库 db_pursey 后 ， 在 右 侧 页 面 中 会 出 现 如 图 1.78 所 示 的 数据 表 创建 提示 页 面 ， 完 成 数据 
表 的 创建 操作 。 

首先 在 表单 中 输入 数据 表 的 名 称 和 字段 数 ， 然 后 单 击 “ 执 行 ” 按 钮 ， 进 入 各 个 字段 的 详细 信息 录 
入 表单 ， 包 括 字段 名 、 数 据 类 型 、 长 度 / 值 、 属 性 、 默 认 值 、 额 外 和 索引 的 类 型 等 。 在 这 里 就 完成 了 对 
表 结 构 的 详细 设置 ， 如 图 1.79 所 示 。 


加 服务 器 : localhost ， 数据 库 : db_pursey ， 国 表 :tb_admin 


字 及 类 型 加 长 度 / 值 ,1 整理 Null 祷 外 加 
em non) fautoncementH © 
[rame [vacmr 司 同 [ov2312 ennese ad ” 司 [rotnw 司 | 


保 让 | 或 添加 [7 ”字段 执行 | 


1.79 ”创建 表 信 息 
\ .66* 
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当 所 有 的 信息 都 输入 以 后 ， 就 可 以 单 击 “ 保 存 ” 按 钮 ， 成 功 创建 数据 表 tb_admin。 一 个 新 的 数据 
表 被 创建 后 ， 进 入 到 数据 表 页 面 中 ， 在 这 里 可 以 通过 改变 表 的 结构 来 修改 表 ， 可 以 执行 添加 新 的 列 、 
删除 列 、 索 引 列 、 修 改 列 的 数据 类 型 或 者 字段 的 长 度 / 值 等 操作 ， 如 图 1.80 所 示 。 


加 服务 器 : localhost ， 昌 数据 库 : db_pursey ， 国 表 :tb_admin 


操作 
auto-increme x 
厂 bookname varchar(50) gb ESE 可 2 国 
厂 price varchar(50) gb2312_chinese_ci 否 


设置 主键 
人 全 选 /全 部 不 选 肉 史 项 围 放 X 圈 回 图 加 1 


镍 第 |1 列 创建 索引 执行 


图 1.80 操作 列表 


2. 删除 数据 表 


执行 删除 表 的 操作 很 简单 ， 只 要 单 击 图 1.80 所 示 页 面 上 方 的 “删除 ”按钮 ， 就 可 以 轻松 地 删除 当 
前 数据 表 。 


1.16 ”本章 总 结 


本 章 依据 软件 开发 流程 介绍 了 九 九 度 供求 信息 网 的 开发 过 程 。 在 开发 任何 一 个 项 目前 ， 首 先 要 充 
分 做 好 前 期 准备 ， 如 完善 的 需求 分 析 、 清 晰 的 业务 流程 、 合 理 的 程序 结构 等 ， 这 样 ， 在 后 期 的 程序 开 
发 中 才 会 得 心 应 手 ， 有 备 而 无 患 。 通 过 本 章 的 学 习 ， 读 者 可 以 了 解数 据 库 建 模 的 概念 ， 掌 握 
PowerDesigner 数据 库 建 模 的 方法 ， 熟 悉 框 架 技 术 在 Web 应 用 程序 中 的 应 用 。 
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随 着 人 类 文明 的 不 断 进 步 ， 网 络 这 个 虚拟 世界 也 在 发 生 着 变化 ， 现 实 世界 中 的 
所 有 内 容 在 网 络 上 都 有 反映 。 现 实 世界 中 物 以 类 聚 ， 人 以 群 分 ， 网 络 世 界 中 也 形成 
各 式 各 样 的 社区 。 这 种 社区 建立 在 特殊 的 兴趣 点 上 (如 体育 、 新 闻 、 宠 物 、 电 影 和 
游戏 等 ) ， 特 殊 的 人 群 上 ， 特 殊 的 有 要 好 上 ， 或 者 是 特殊 的 服务 上 等 。 社 区 也 是 一 种 
特定 的 商业 模式 ， 它 本 身 可 以 进行 电子 商务 ， 也 可 以 完全 与 商务 无 关 。 

所 谓 网 上 社区 是 指 包 括 BBS 论坛 、 聊 天 室 、 博 客 等 形式 在 内 的 网 上 交流 空间 ， 
同一 主题 的 网 上 社区 集中 了 具有 共同 兴趣 的 访问 者 ， 由 于 有 众多 用 户 的 参与 ， 因 此 
具备 了 交流 的 功能 ， 成 为 一 个 营销 场所 。 

网 上 社区 有 各 种 不 同 的 表现 形式 和 规模 ， 有 个 人 创办 的 社区 ， 功 能 和 界面 追求 
时 南 、 个 性 突出 ; 有 大 型 的 商业 性 质 社 区 ， 以 赢利 为 目的 ， 分 类 多 元 化 ， 适 合 不 同 
类 型 的 网 民 。 

本 章 开发 的 BCTY365 网 上 社区 主要 面向 程序 开发 人 员 ， 集 论坛 、 留 言 板 、 软 
件 下 载 、 升 级 下 载 、 技 术 支 持 和 在 线 购 物 等 功能 于 一 身 ， 既 是 一 个 程序 开发 者 交流 
的 平台 ， 更 是 一 个 网 络 营 销 的 场所 。 通 过 阅读 本 章 ， 可 以 学 习 到 : 

MW 网 上 社区 开发 的 基本 过 程 
如 何 做 需求 分 析 和 系统 设计 
如 何 设计 和 创建 数据 库 、 数 据 表 
如 何 设计 公共 类 
软件 上 传 和 下 载 功能 的 实现 方法 
在 线 论 坛 功 能 的 实现 方法 
在 Linux 操作 系统 下 搭建 PHP 开发 环境 
在 Linux 操作 系统 下 发 布 网 站 
在 线 支付 技术 


至 于 于 于 于 于 于 至 
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2.1 开发 背景 


随 着 市 场 竞 争 的 日 益 激 烈 ， 企 业 的 生存 和 发 展 之 路 更 加 艰难 ， 要 想 使 企业 保持 旺盛 的 生命 力 ， 企 
业 必 须要 跟 上 时 代 发 展 的 脚步 ， 不 断 为 企业 注入 新 的 活力 。 某 科技 公司 为 适应 市 场 的 需求 ， 增 加 公司 
在 互联 网 上 的 影响 力 ， 将 开发 一 个 网 上 社区 系统 ， 为 广大 的 编程 爱好 者 提供 一 个 交流 的 平台 ， 并 且 以 
此 来 推广 该 公司 的 软件 产品 。 


2.2 ”系统 分 析 


当 一 个 开发 项 目 被 确立 时 ， 首 先 要 做 的 就 是 需求 分 析 、 可 行 性 分 析 ， 然 后 编写 项 目 计划 书 ， 以 使 
项 目 开 发 人 员 了 解 和 人 掌握 网 站 的 前 期 策划 和 网 站 开发 流程 。 


2.2.1 需求 分 析 


在 开发 网 上 社区 之 前 ， 首 先 要 明确 所 要 开发 的 社区 属于 什么 类 型 ， 是 个 人 的 社区 系统 ， 还 是 商业 
化 的 社区 系统 ， 并 且 要 知道 开发 的 社区 是 面向 什么 样 的 人 群 ， 是 普通 网 民 ， 还 是 专业 的 技术 人 员 ， 或 
者 是 其 他 的 特殊 群体 。 针 对 不 同 的 人 群 ， 社 区 应 该 具有 不 同 的 特点 。 当 明确 了 这 些 ， 项 目 开发 的 思路 
就 清晰 了 ， 然 后 再 对 网 站 上 一 些 相关 的 社区 进行 考察 、 分 析 ， 从 中 吸取 经 验 ， 并 结合 企业 的 要 求 以 及 
实际 的 市 场 调查 结果 ， 提 出 一 个 合理 的 网 上 社区 网 站 功能 架构 。 本 网 站 需求 如 下 : 
网 站 设计 页 面 要 求 整洁 、 美 观 大 方 ， 能 够 展示 企业 形象 。 
网 站 页 面具 有 banner 广告 ， 树 立 企业 良好 的 口碑 宣传 。 
设计 主要 从 编程 者 的 角度 考虑 ， 为 编程 者 解决 在 开发 中 出 现 的 问题 。 
展示 出 企业 全 力 推出 的 软件 产品 和 提供 的 免费 软件 ， 以 此 吸引 浏览 者 。 
提供 一 个 良好 的 网 上 购物 的 操作 平台 。 
提供 技术 支持 ， 解 决 编程 过 程 中 常见 的 问题 。 
提供 一 个 讨论 和 研究 问题 的 平台 。 
做 到 让 广大 浏览 者 关注 企业 的 动态 。 
为 客户 提供 反馈 信息 的 平台 ， 能 够 作 到 及 时 与 客户 进行 沟通 。 
完善 的 后 台 管理 系统 。 


办 办 办 办 办 办 办 多 


2.2.2 可行 性 分 析 


可 行 性 分 析 是 世界 上 普遍 采用 的 一 种 研究 工程 项 目 是 否 可 行 的 科学 。 其 通过 各 种 有 效 的 方法 ， 对 
工程 项 目 进行 分 析 ， 从 技术 、 经 济 、 市 场 等 方面 加 以 评价 ， 最 终 给 投资 决策 者 提供 是 否 选择 该 项 目 进 


行 开发 的 依据 。 
0%. 
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BCTY365 网 上 社区 项 目 开发 的 可 行 性 分 析 主要 从 以 下 两 个 方面 考虑 。 

1. 经 济 可 行 性 分 析 

企业 为 扩大 公司 的 影响 力 ， 推 出 软件 产品 ， 采 用 网 上 社区 的 形式 在 网 络 上 进行 推广 ， 不 但 可 以 汇 
聚 更 多 的 人 气 ， 而 且 可 以 让 更 多 的 人 了 解 该 企业 ， 从 而 达到 推广 企业 软件 产品 的 目的 ， 最 终 为 企业 带 
来 更 大 的 收益 。 更 重要 的 一 点 是 采取 该 方法 的 成 本 相对 其 他 的 电视 广告 或 者 人 力 宣传 的 成 本 要 低 得 多 ， 
虽然 周期 很 长 ， 但 是 却 能 够 取得 长 期 的 收益 。 

2. 技术 可 行 性 分 析 

网 上 社区 系统 的 开发 采用 的 是 Apache+PHP+phpMyadmin+MySQL 5.0， 开 发 软件 都 是 免费 的 ， 直 
接 可 以 从 网 上 下 载 ， 无 须 支付 任何 费用 。 要 完成 BCTY365 网 上 社区 系统 的 开发 ， 必 须 能 够 配置 PHP 
程序 开发 的 环境 ， 掌 握 在 线 支 付 、 购 物 车 和 在 线 论坛 技术 。 


2.2.3 编写 项 目 计划 书 


根据 《GB8567 一 88 计算 机 软件 产品 开发 文件 编制 指南 》 中 的 项 目 开 发 计划 要 求 ， 结 合 单位 实际 情 
况 ， 设 计 项 目 计划 书 如 下 : 

1. 引言 

(1) 编写 目的 

为 了 保证 项 目 开 发 人 员 按 时 保质 地 完成 预订 目标 ， 更 好 地 了 解 项 目 实际 情况 ， 按 照 合 理 的 顺序 开 
展 工 作 ， 现 以 书面 的 形式 将 项 目 开发 生命 周期 中 的 项 目 任务 范围 、 项 目 团队 组 织 结构 、 团 队 成 员 的 工 
作 责 任 、 团 队 内 外 沟通 协作 方式 、 开 发 进度 、 检 查 项 目 工 作 等 内 容 描述 出 来 ， 作 为 项 目 相 关 人 员 之 间 
的 共识 和 约定 ， 项 目 生 命 周 期 内 的 所 有 项 目 活动 的 行动 基础 。 

(2) 背景 

BCTY365 网 上 社区 系统 是 本 公司 与 X X X 科 技 有 限 公 司 签 定 的 待 开 发 项 目 ， 网 站 性 质 为 信息 服务 
类 型 ， 为 企业 与 客户 、 浏 览 者 和 会 员 之 间 提 供 一 个 技术 交流 平台 ， 并 且 全 力 推出 企业 的 软件 产品 。 项 
目 周 期 为 两 个 月 ， 项 目 背景 规划 如 表 2.1 所 示 。 


表 2.1 项 目 背 景 规划 


项 目 名 称 签 定 项 目 单位 项 目 负责 人 项 目 承担 部 门 
甲 方 ，X X X 信 息 科技 有 限 公司 甲 方 : 赵 经 理 设计 部 门 
BCTY365 网 上 社区 系统 开发 部 门 


乙方 : XX X 网 络 科 技 有 限 公 司 乙方 : 张 经 理 


测试 部 门 


2. 概述 
(1) 项 目 目标 
项 目 目标 应 当 符合 SMART 原则 ， 把 项 目 要 完成 的 工作 用 清晰 的 语言 描述 出 来 。BCTY365 网 上 社 
区 系统 的 项 目 目标 如 下 : 


BCTY365 网 上 社区 系统 主要 用 于 在 网 络 中 树立 企业 的 形象 ， 为 程序 开发 者 提供 一 个 交流 的 平台 ， 


Sn 
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拉 近 企业 与 客户 、 会 员 和 浏览 者 之 间 的 距离 ， 从 而 达到 推广 企业 软件 产品 的 目的 。 整 个 项 目 需要 两 个 
月 结束 ， 交 给 客户 进行 验收 。 

(2) 产品 目标 与 范围 

一 方面 BCTY365 网 上 社区 系统 能 够 为 企业 节省 大 量 人 力 资源 , 企业 不 再 需要 大 量 的 业务 人 员 去 跑 
市 场 ， 间 接 为 企业 节约 了 成 本 。 另 一 方面 ，BCTY365 网 上 社区 系统 能 够 收集 海量 编程 问题 的 解决 方案 
和 好 的 建议 ， 将 会 有 大 量 用 户 访问 网 站 ， 有 助 于 提高 企业 知名 度 。 

(3) 应 交付 成 果 

项 目 开发 完成 后 ， 交 付 的 内 容 如 下 : 

回 ”以 光盘 的 形式 交付 BCTY365 网 上 社区 系统 的 源 程序 、 网 站 数据 库 文件 、 系 统 使 用 说 明 书 。 

客户 方 应 用 自己 的 服务 器 ， 因 此 需要 乙方 架设 Apache 服务 器 ， 安 装 PHP 开发 环境 ， 协 助 甲 

方 购买 域名 ， 将 开发 的 BCTY365 网 上 社区 系统 发 布 到 互联 网 上 运行 。 
网 站 发 布 到 互联 网 上 以 后 ， 进 行 后 期 的 6 个 月 无 偿 维护 与 服务 ， 超 过 6 个 月 后 进行 网 站 有 傍 
维护 与 服务 。 

(4) 项 目 验收 方式 与 依据 

项 目 验收 分 为 内 部 验收 和 外 部 验收 两 种 方式 。 在 项 目 开 发 完成 后 ， 首 先进 行内 部 验收 ， 由 系统 测 
试 员 根 据 用 户 需 求 和 项 目 目 标 进行 验收 。 项 目 在 通过 内 部 验收 后 ， 然 后 交 给 用 户 进 行 验 收 ， 验 收 的 主 
要 依据 为 需求 规格 说 明 书 。 

3. 项 目 团队 组 织 

(1) 组 织 结构 

为 了 完成 BCTY365 网 上 社区 系统 的 项 目 开发 ， 公 司 组 建 一 个 临时 的 项 目 团队 ， 由 项 目 经 理 、 系 统 
分 析 师 、PHP 开发 工程 师 、 网 页 设计 师 和 系统 测试 员 构成 ， 如 图 2.1 所 示 。 


项 目 经 理 


系统 分 析 古 PHP 开发 工程 师 网 页 设计 师 系统 测试 员 
2.1 项 目 团 队 组 织 结构 图 
(2) 人 员 分 工 
为 了 明确 项 目 团队 中 每 个 人 的 任务 分 工 ， 现 制定 人 员 分 工 表 ， 如 表 2.2 所 示 。 


本 
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表 2.2 人 员 分 工 表 
技术 水 平 


负责 项 目的 审批 、 决 策 的 实施 、 项 目的 前 期 
张 达 明 项 目 开发 部 | 项 目 经 理 分 析 、 策 划 、 项 目 开发 进度 的 跟踪 、 项 目 质 
量 的 检查 

王 言 辉 “| 高 级 系统 分 析 师 项 目 开 发 部 | 系统 分 析 师 负责 系统 功能 分 析 、 系 统 框架 设计 
潘 攀 。” ”| 高 级 PHP 工 程 师 项 目 开发 部 | PHP 开 发 工程 师 | 负责 软件 前 后 台 设计 与 编码 

刘 悦 高 级 美工 设计 师 设计 部 网 页 设计 师 负责 网 页 风格 的 确定 、 网 页 图 片 的 设计 


对 软件 进行 测试 、 编 写 软件 测试 文档 
2.3 ”系统 设计 


2.3.1 系统 目标 


根据 对 目前 网 络 上 各 种 社区 的 分 析 和 研究 ， 结 合 本 项 目的 实际 需求 ， 且 在 设计 时 应 该 满足 以 下 
目标 : 
界面 设计 美观 大 方 、 方 便 、 快 捷 、 操 作 灵 活 ， 树 立 企业 形象 。 
功能 完善 、 结 构 清晰 。 
重点 突出 企业 的 软件 产品 。 
及 时 更 新 网 站 公告 。 
及 时 查阅 和 回复 客户 反馈 信息 。 
为 用 户 提 供 沟通 和 交流 的 平台 。 
购物 车 模块 的 设计 结构 合理 、 流 程 清晰 。 
购物 结算 功能 设计 符合 逻辑 ， 计 算 准 确 。 
订单 处 理 功 能 的 设计 及 时 、 准 确 、 安 全 。 
网 上 支付 功能 的 设计 处 理 好 与 网 上 银行 之 间 数 据 的 传递 ， 确 保安 全 、 可 靠 。 
具备 完善 的 后 台 管理 功能 ， 能 够 及 时 、 准 确 地 对 网 站 进行 维护 和 更 新 。 
系统 运行 稳定 ， 具 备 良 好 的 防范 措施 。 


因 因 办 办 办 办 办 办 办 办 多 轨 


2.3.2 ”系统 功能 结构 
结合 需求 分 析 和 系统 目标 中 的 内 容 ，BCTY365 网 上 社区 系统 的 功能 结构 已 经 设计 完成 。 为 了 使 读 


者 能 够 更 清楚 地 了 解 网 站 的 结构 ， 下 面 给 出 BCTY365 网 上 社区 前 台 和 后 台 功 能 模块 结构 图 。 
BCTY365 网 上 社区 前 台 管 理 系 统 的 功能 设计 如 图 2.2 所 示 。 


RS 
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图 2.2 网 上 社 | 
BCTY365 网 上 社区 后 台 管 理 系统 的 功能 设计 如 图 2.3 所 示 。 


添加 升级 包 ”上 | 一 


添加 序列 号 [于 
编辑 序列 号 [一 


图 


2.3 网 上 社 


区 前 台 


功能 模块 结构 图 


二 


订单 处 理 


工行 网 上 支付 


购物 车 


一 购物 结算 


| 添加 编程 词典 版 本 


编辑 编程 词典 版 本 


添加 编程 词典 


编辑 编程 词典 
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2.3.3 系统 预览 


BCTY365 网 上 社区 系统 由 多 个 程序 页 面 组 成 ， 下 面 给 出 儿 个 典型 页 面 ， 其 他 页 面 参见 光盘 中 的 源 
程序 。 

前 台 首页 如 图 2.4 所 示 , 该 页 面 用 于 展示 本 系统 的 功能 模块 , 突出 企业 的 形象 , 推广 企业 的 软件 产 
品 。 后 台 首 页 如 图 2.5 所 示 ， 该 页 面 用 于 实现 对 编程 词典 、 技 术 支持 、 软 件 升级 、 软 件 试用 等 内 容 的 


EE 


本 
多 
EE 


— — "EE E | 
2.4 前台 首页 (光盘 \TM\02\bcty365\index.php) ”图 2.5 后 台 首 页 (光盘 \TM\02\bcty365\ admin\default.php) 

在 线 订购 模块 的 页 面 效 果 如 图 2.6 所 示 , 该 页 面 主要 用 于 展示 本 企业 在 线 推出 的 软件 产品 , 实现 对 
产品 的 在 线 购买 功能 。 软件 下 载 模块 的 页 面 效 果 如 图 2.7 所 示 , 该 页 面 主要 用 于 展示 本 企业 提供 的 免费 


要 关中 (可 :Dalirggel Cozyrzeht x007 电池 村 者 明 日 HR 从 司 


软件 ， 并 且 提供 下 载 链接 。 


©) BCTY365 社 区 网 ， 找 你 想 要 的 
assets 


BCTY365 社 区 网 ， 找 你 想 要 的 


六 避雷 的 史 得 忆 什 洒 直 


图 2.6 在 线 订购 (光盘 \TM\02\bcty365\ morebccd.php) 2.7 软件 下 载 (光盘 \TM\02\bcty365\ rjxz.php) 


社区 论坛 模块 的 页 面 效果 如 图 2.8 所 示 , 该 页 面 主要 用 于 展示 论坛 中 的 各 大 版 块 , 并 且 提 供 超 链接 
跳 转 到 对 应 的 版 块 。 后 台 的 登录 页 面 效果 如 图 2.9 所 示 ， 该 页 面 主要 实现 后 台 管 理 员 登录 。 


SS 
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图 2.8 ”社区 论坛 (光盘 \TM\02\bcty365\bbs_index.php) ”图 2.9 后 台 登 录 (光盘 \TMW2\bcty365\admin\index.php) 
2.3.4 开发 环境 


在 开发 BCTY365 网 上 社区 时 ， 该 项 目 使 用 的 软件 开发 环境 如 下 : 
1. 服务 器 端 
操作 系统 : Windows XP Server/Linux (推荐 ) 。 
服务 器 :Apache 2.0。 
PHP 软件 : PHP 5.0。 
数据 库 : MySQL 5.0。 
MySQL 图 形 化 管理 软件 : PhpMyAdmin-2.9.0。 
开发 工具 : Dreamweaver 8。 
浏览 器 : IE 6.0 及 以 上 版 本 。 
分 辨 率 : 最 佳 效果 1024X 768 像素 。 
客户 端 
浏览 器 : IE 6.0 及 以 上 版 本 。 
分 辨 率 : 最 佳 效 果 1024X 768 像素 。 


SS 


2.3.5 文件 夹 组 织 结构 


在 进行 网 站 开发 之 前 ， 要 对 网 站 的 整体 文件 夹 组 织 架构 进行 规划 。 对 网 站 中 使 用 的 文件 进行 合理 
的 分 类 ， 分 别 放置 于 不 同 的 文件 夹 下 。 通 过 对 文件 夹 组 织 架 构 的 规划 ， 可 以 确保 网 站 文件 目录 明确 、 
条 理 清晰 ， 同 样 也 便于 网 站 后 期 的 更 新 和 维护 。 本 案例 的 文件 夹 组 织 架 构 规 划 如 图 2.10 所 示 。 
.75 。 多 


PHP 项 目 开发 全 程 实录 


BB bety365 
日 司 “in 一 一 一 一 一 一 一 一 一 一 用 于 存 博 网 站 后 台 管理 文件 
回 heedinages 一 一 一 一 一 一 一 用 于 存 请 编程 词典 的 界面 
日 一 一 一 一 一 一 一 一 一 用 于 存 傅 网 站 后 台 使 用 的 Css 文件 
外 “inae: 一 一 一 一 一 一 一 一 用 于 存储 交 站 后 台 的 图 片 文件 
同 jx 一 一 一 一 一 一 一 一 一 一 用 于 存 傅 升 级 下 载 的 文件 
自 ft 一 一 一 一 一 一 一 一 一 用 于 存储 可 下 载 的 软件 
同 om 一 一 一 一 一 一 一 一 一 一 一 用 于 存储 连接 数据 库 的 文件 
和 目 “一 一 一 一 一 一 一 一 一 有 于 存 仿 网 站 前 台 使 用 的 css 文件 
日 “inaees 一 一 一 一 一 一 一 一 一 一 用 于 存储 网 站 前 台 使 用 的 图 片 文件 
同 wfile 一 一 一 一 一 一 一 一 一 一 用 于 存 针 网 站 论坛 中 上 传 的 图 片 文件 


图 2.10 文件 夹 组 织 结构 


2.4 在 Linux 操作 系统 下 搭建 PHP 开发 环境 


Red Hat Linux 9 是 Linux 众多 版 本 中 比较 大 众 化 的 一 版 。 在 安装 系统 时 ， 如 果 选 择 完全 安装 或 者 选 
择 Apache、MySQL、PHP 的 安装 包 ， 则 三 者 将 被 安装 到 系统 中 ， 用 户 只 需 将 Apache 和 MySQL 服务 启 
动 就 可 以 使 用 二 者 ， 非 常 方便 ， 但 是 Apache 和 MySQL 的 版 本 可 能 不 是 很 理想 。 为 了 能 够 创建 一 个 良好 
的 PHP 开发 环境 ， 这 里 将 详细 介绍 自行 在 Linux 下 安装 和 配置 Apache2+MySQL5.0+PHP5 的 方法 。 

首先 应 该 到 相关 官方 网 站 下 载 三 者 的 安装 包 : 

httpd-2.0.58.tar.gz 或 更 高 版 本 (http://httpd.apache.org/) 。 

mysql-standard-5.0.0-alpha-pc-linux-i686.tar.gz 或 更 高 版 本 (http:/www.mysql.com/) 。 

php-5.0.0.tar.gz 或 更 高 版 本 (http://www.php.net/》。 

libxml2-2.5.10.tar.gz 或 更 高 版 本 (如 果 读 者 系统 中 的 libxml2 的 版 本 已 经 等 于 或 高 于 该 版 本 可 以 不 
必 下 载 该 安装 包 ) 。 


2.4.1 Linux 下 Apache 的 安装 配置 


首先 将 下 载 的 httpd 安装 包 复 制 到 适当 的 位 置 ， 例 如 /usr/local/work 下 (如果 目录 不 存在 ， 可 以 建 
立 该 目录 ) 。 打 开 Red Hat Linux 9 的 主 菜 单 ， 选 择 “ 系 统 工具 ”， 在 弹出 的 菜单 中 选择 “终端 ”命令 ， 
将 打开 如 图 2.11 所 示 的 终端 对 话 框 。 


人 说 明 : Linux 下 Apache、MySQL 及 PHP 的 安装 都 是 在 如 图 2.11 所 示 的 终端 命令 窗口 通过 命令 方 
式 实现 的 。 


文件 E) ”编辑 EE) ”查看 (V) 终端 D 转 至 G) 帮助 ID) 
[root@localhost root]# 之 


2.11 Red Hat Linux 9 的 终端 命令 对 话 框 


Sr 
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在 该 对 话 框 中 输入 如 下 命令 进入 work 目录 : 
cd /usr/local/work 
在 work 目录 中 输入 如 下 命令 解压 httpd-2.0.58.tar.gz: 
tar xfz httpd-2.0.58.tar.gz 
进入 解压 后 的 目录 httpd-2.0.58: 
cd httpd-2.0.58 
建立 makefile， 并 将 Apache2 安装 到 /usr/local/apache2 目录 下 : 
‘/configure -prefix=/usrlocal/apache -enable-module=so 
开始 编译 : 
make 
开始 安装 到 设置 的 目录 去 : 
make install 
到 此 Apache2 的 安装 工作 完成 ， 可 以 在 每 次 启动 系统 时 通过 如 下 命令 启动 或 重新 启动 Apache2 
服务 : 


/usr/local/apache2/bin/apachectl start 

/usr/local/apache2/bin/apachectl restart 

打开 浏览 器 ， 在 地 址 栏 中 输入 http://127.0.0.1 或 者 http://localhost， 按 Enter 键 ， 如 果 出 现 如 图 2.12 
所 示 的 页 面 ， 则 说 明 Apache2 安装 成 功 。 


文件 (D 三 EE 查 看 V 转 束 @ 蔬 守 时 工 ND 琶 POWD 区 WW 


高 - 向- t、 季 [Eeeeeem 器 世 是 品 
允 上 看 对 Hi 生 要 Red nt Nend 散 Smpm 四 shm 四 nan 四 Inn 
嫩 能 看 见 这 个 页 面 ， 说 明 Apasbe_web_iervrsx 已 经 安装 成 功 。 您 可 以 在 这 个 目录 中 增加 内 
容 ， 或 者 把 这 个 页 面 知 换 掉 。 
这 不 是 你 想 看 见 的 页 面 吧 ? 


-站 点 的 设 于 。 加 时 有 终 问 ， 计 咨询 维 


之 所 以 会 乔 见 这 个 页 面 。 是 因为 网 站 兰 理 只 改变 了 
护 此 站 点 的 人 员 会 如 用 的 网 站 医务 骂 软 件 的 开发 者 ， 不 负 


ac 
寺 此 站 点 的 维护 工作 ， 也 无 法 为 您 
Apache 立 挡 已 经 包含 在 此 改行 版 中 


您 可 以 在 使 用 Apache 的 网 站 服务 器 上 ， 自 由 地 侠 用 下 面 的 图 片 。 感 谢 使 用 Apachel 


i 色 一 一 一 呈 


a : 
er 吧 丽 | [ 


晤 外 人 RR 全 
图 2.12 测试 Apache 服务 器 


2.4.2 Linux 下 MySQL 的 安装 配置 


将 mysql-standard-5.0.0-alpha-pc-linux-i686.tar.gz 复制 到 /usrlocal/work 目录 下 ， 建 立 MySQL 账号 : 


groupadd mysql 
在 组 群 中 加 入 MySQL 
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useradd -g mysql mysql 

进入 local 目录 : 
cd /usrlocal 

将 mysql-standard-5.0.0-alpha-pc-linux-i686.tar.gz 解压 到 该 目录 : 
ES 

考虑 到 MySQL 数据 库 升级 的 需要 ， 所 以 通常 以 链接 的 方式 建立 /usr/local/mysql 目录 : 
ln-s mysql-standard-5.0.0-alpha-pc-linux-i686.tar.gz mysql 

进入 MySQL 目录 : 
cd mysql 

在 /usr/local/mysql/data 中 建立 MySQL 的 数据 库 : 
Er | 

修改 文件 权限 : 


chown —R root . 

chown -R mysql data 

chgrp -R mysql . 

到 此 MySQL 安装 成 功 。 可 以 通过 在 终端 中 输入 如 下 命令 启动 MySQL 服务 : 


/usr/local/mysql/bin/mysqld_safe -user=mysql & 
启动 MySQL 后 输入 如 下 命令 查看 安装 结果 : 
/usr/local/mysql/bin/mysql -uroot 
如 果 终 端 对 话 框 出 现 如 图 2.13 所 示 的 提示 ， 则 说 明 MySQL 安装 成 功 。 


| 文件 ED 编辑 里) ”查看 (WD 终端 了 转 到 G) 帮助 

[root@localhost root]# /usr/local/nysql/bin/nysql -uroot -pl23 
Wicone to the MSGL nonitor. Cnmmands end with ; or \g. 

Your MSGL connection id is 1 to server version: 5.0.0-alpha-standard 


Type ‘help:’ or '\h' for help. Type ‘\e’ to clear the buffer. 


[mysql> | | 


图 2.13 测试 MySQL 


2.4.3 Linux 下 PHP 的 安装 配置 


首先 查看 系统 中 libxml2 的 版 本 号 ， 如 果 libxml2 的 版 本 号 小 于 2.5.10， 则 需要 安装 
libxml2-2.5.10.tar.gz 或 更 高 版 本 ， 因 为 PHP5 必须 在 libxml2 的 版 本 大 于 2.5.10 的 前 提 下 才能 够 安装 。 
将 libxml2-2.5.10.tar.gz 复制 到 /usr/local/work 目录 下 ， 并 进入 该 目录 : 


cd /usr/local/work 
。78 。 
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解压 libxml2-2.5.10.tar.gz: 
tar xfz libxml2-2.5.10.tar.gz 
进入 该 目录 : 
cd libxml2-2.10 
建立 makefie 并 将 libxml2 安装 到 /usr/local/libxml2 下 : 
./configure -prefix=/usrlocallibxml2 
开始 编译 : 
make 
开始 安装 到 设置 的 目录 去 : 
make install 


到 此 libxml2 安装 成 功 。 
将 php-5.0.0.tar.gz 复制 到 /usr/local/work 目录 下 ， 并 进入 该 目录 : 


cd /usr/local/work 


解压 php-5.0.0.tar.gz: 


tar xfz php-5.0.0.tar.gz 
进入 php-5.0.0 目录 : 
cd php-5.0.0 


建立 makefile: 


./configure —with-apxs2=/usr/local/apache2/bin/apxs \ 
-with-mysql=/usr/local/mysql\ 
~—with-libxml-dir=/usr/local/libxml2 


开始 编译 : 
make 
开始 安装 : 
make install 
复制 php.ini-dist 或 php.ini-recommended 到 /usr/local/lib 目录 ， 并 命名 为 php.ini: 
cp php.ini-dist /usr/local/lib/php.ini 
更 改 httpd.conf 文件 相关 设置 , 该 文件 位 于 /usr/local/apache2/conf 中 。 找 到 该 文件 中 的 如 下 指令 行 : 
AddType application/x-gzip .gz gz 
在 该 指令 后 加 入 如 下 指令 : 


AddType application/x-httpd-php .php .phtml 
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重新 启动 Apache， 并 在 Apache 主 目 录 下 建立 文件 testphp: 


<?php 
phpinfo0; 


27> 
在 浏览 器 中 输入 http://127.0.0.1/test.php， 按 Enter 键 ， 如 果 出 现 如 图 2.14 所 示 的 页 面 ， 则 PHP 安 


装 成 功 。 


[ED 说 明 : Apache2 默认 主 目 录 为 /usr/local/apache2/htdocs。 
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图 2.14 PHP 测试 
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0 技巧 : 安装 文件 的 路 径 要 遵循 一 定 的 客观 原则 ， 为 了 避免 在 Windows 和 Linux 间 移 植 程序 时 带 来 的 
不 便 ， 选 择 D:\usr\local\php 的 目录 时 要 和 在 Linux 下 的 安装 目录 相 匹 配 。 建 议 最 好 不 要 选择 
中 间 有 空格 的 目录 ， 如 E:\program Files\PHP， 这 样 做 会 导致 一 些 未 知 错误 或 崩 演 发 生 。 


2.5 数据库 设计 


开发 一 个 功能 完善 的 网 上 社区 离 不 开 数据 库 的 支持 ， 只 有 拥有 了 强大 的 数据 库 ， 网 上 社区 才能 够 
存储 大 量 的 数据 信息 ， 实 现 更 多 、 更 好 的 功能 来 吸引 更 多 的 社区 成 员 。 本 节 将 对 BCTY365 网 上 社区 数 
据 库 的 设计 进行 详细 介绍 。 


2.5.1 数据 库 分析 


BCTY365 网 上 社区 是 一 个 中 型 的 面向 软件 开发 者 的 程序 ， 考 虑 到 开发 的 成 本 、 搭 配 的 合理 性 以 及 
操作 的 灵活 性 等 ， 使 用 了 MySQL 数据 库 。 从 成 本 考虑 MySQL 数据 库 是 完全 免费 的 ， 可 以 在 网 上 免费 
下 载 ; 从 匹配 的 角度 讲 PHP 与 MySQL 数据 库 一 直 是 公认 的 最 佳 搭档 ; MySQL 数据 库 不 但 可 以 在 命令 
模式 下 进行 操作 ， 而 且 还 配备 了 一 些 比 较 流 行 的 图 形 化 管理 工具 ， 如 phpMyAdmin 等 ， 可 以 轻松 地 对 
MySQL 数据 库 中 的 数据 进行 操作 。 


So 
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2.5.2 ”数据 库 概 念 设计 


根据 上 述 各 节 对 BCTY365 网 上 社区 系统 做 的 需求 分 析 和 系统 设计 ， 规 划 出 BCTY365 网 上 社区 的 
实体 关系 E-R 图 。 其 中 包括 注册 用 户 实体 、 发 帖 信息 实体 、 回 帖 信息 实体 、 订 单 信息 实体 和 编程 词典 
信息 实体 ， 其 他 还 有 一 些 辅助 的 实体 ， 是 对 上 述 实体 中 内 容 的 补充 。 由 于 涉及 的 实体 较 多 ， 这 里 只 刀 
注册 用 户 实体 、 发 帖 信息 实体 和 订单 信息 实体 的 E-R 图 进行 介绍 。 

1. 注册 用 户 实体 

注册 用 户 实体 用 于 存储 用 户 注册 信息 ， 包 括 编号 、 用 户 名 、 真 实 姓 名 、 密 码 、 邮 箱 、 性 别 、 电 话 、 
QQ 号 码 、 家 庭 地 址 、 访 问 次 数 、 注 册 时 间 、 最 后 一 次 登录 时 间 、IP 地 址 、 邮 政 编码 、 用 户 类 型 、 密 
码 提示 问题 、 密 码 答案 、 真 实 密码 、 表 情 图 、 发 帖 次 数 属性 。 注 册 用 户 实体 的 E-R 图 如 图 2.15 所 示 。 


图 2.15 注册 用 户 实体 E-R 图 
2. 发 帖 信息 实体 
发 帖 信息 实体 用 于 存储 登录 本 社区 的 会 员 在 论坛 中 发 布 帖子 的 相关 信息 ， 包 括 编号 、 用 户 名 ID、 
帖子 类 别 、 帖 子 标题 、 帖 子 内 容 、 发 帖 时 间 、 最 后 回复 时 间 、 表 情 图 、 访 问 次 数 、 是 否 顶 帖 、 上 传 图 
片 属性 。 发 帖 信息 实体 的 E-R 图 如 图 2.16 所 示 。 


2.16 发帖 信息 实体 的 E-R 图 


3. 订单 信息 实体 
订单 信息 实体 存储 用 户 在 线 购买 时 填写 的 订单 信息 ， 包 括 编 号 、 用 户 名 、 性 别 、 家 庭 地 址 、 邮 政 
编码 、QQ 号 码 、 邮 箱 、 手 机 号 码 、 电 话 号 码 、 收 货 方式 、 邮 资 、 产 品 金额 、 订 单 时 间 、 订 单 号 、 选 择 
城市 等 属性 。 订 单 信息 实体 的 E-R 图 如 图 2.17 所 示 。 
.81。 乡 
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图 2.17 订单 信息 实体 E-R 图 


2.5.3 创建 数据 库 及 数据 表 


在 BCTY365 网 上 社区 系统 中 应 用 的 是 db_bcty365 数据 库 ， 其 中 涉及 18 个 数据 表 ， 数 据 表 的 名 称 
和 功能 如 图 2.18 所 示 。 


加 服务 器 : localhost ， 昌 数据 库 : db_bcty365 


表 类 型 整理 说 明 
tb_bb MyISAM gb2312_chinese_ci 编程 词典 版 本 信息 表 
th_bbqb MyISAM ”gb2312_chinese_ci ”版 本 之 间 区 别 信息 表 
th_bbs MylSAM ”gb2312_chinese_ci 论坛 发 帖 信息 表 
th_bccd MylSAM gb2312_chinese_ci 编程 词典 信息 表 
th_city MylSAM ”gb2312_chinese_ci 城市 信息 表 
tb_cjwt MylSAM gb2312_chinese_ci ”常见 问题 信息 表 
tb_dd MyISAM gb2312_chinese_ci 订单 信息 表 
th_reply MylISAM ”gb2312_chinese_ci 论坛 回帖 信息 表 
th_sjxz MyISAM gb2312_chinese_ci 软件 升级 下 载 信息 表 
th_soft MyISAM gb2312_chinese_ci 软件 下 载 信息 表 
th_tell MYyISAM gb2312_chinese_ci 社区 公告 信息 表 
th_type MylISAM gb2312_chinese_ci ”社区 模块 类 型 信息 表 


th_type_big MYyISAM gb2312_chinese_ci 论坛 大 类 信息 表 
th type_small MylISAM gb2312_chinese_ci 论坛 小 类 信息 表 


th_user MyISAM gb2312_chinese_ci 注册 用 户 信息 表 
th_xIh MylSAM ”gb2312_chinese_ci 升级 下 载 序列 号 信息 表 
th_bccdj MylSAM ”gb2312_chinese_ci 编程 词典 简介 信息 表 


th_leaveword MylSAM gb2312_chinese_ci 存储 客户 反馈 信息 
2.18 db_bcty365 数据 库 中 使 用 的 数据 表 


本 案例 中 创建 数据 库 和 数据 表 使 用 的 是 phppMyAdmin 图 形 化 管理 工具 ， 下 面 将 介绍 数据 库 和 数据 
表 的 创建 方法 ， 以 及 在 创建 过 程 中 需要 注意 的 一 些 问题 。 


RS 
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1. 数据 库 的 创建 


打开 phpMyAdmin 图 形 化 管理 工具 的 主页 ， 首 先 在 文本 框 中 输入 要 创建 的 数据 库 的 名 称 (如 
db_bcty365) ， 然 后 在 下 拉 列 表 框 中 选择 要 使 用 的 字符 编码 格式 ， 这 里 使 用 的 是 gb2312_chinese_ci,， 如 
图 2.19 所 示 。 最 后 单 击 “ 创 建 ” 按 钮 ， 数 据 库 创建 成 功 。 
localhost phpMyAdmin - 2.9.0.2 


回 服 务 器 版 本 : 5.0 24- client version: 4.1.7 
» Protocol version| 10 HP extensions: mysql 


回 服 E 多 Language 国 : [中 文 - Chinese simplified 局 
富 包 a 开国 狂 志 片 重 phpMyAdmin 官方 网 站 

， [Ch Log] [CYVS] t 

创建 [ChangeLog] [CVS] [Lists] 

[Ea 
跟 权 限 
章 数 据 库 
部 导出 
一 Import phpM UyAdrAin 


图 2.19 ” phpMyAdmin 管理 界面 


技巧 : 创建 数据 库 的 过 程 中 ， 尽 量 使 用 与 程序 内 容 贴切 的 英文 字符 进行 命名 ， 有 助 于 对 数据 库 的 
理解 ; 如 果 使 用 AppServ 配置 PHP 开发 环境 ,那么 在 创建 数据 库 时 不 需要 指定 编码 的 格式 ， 
默认 值 为 gb2312_chinese_ci; 如 果 自 行 配 置 开 发 环境 ， 那 么 就 要 指定 编码 格式 为 gb2312_ 
chinese_ci， 否 则 创建 数据 库 的 编码 格式 为 “latin1_swedish_ci”， 将 导致 数据 库 中 数据 出 现 
乱码 。 

2. 创建 数据 表 

在 成 功 创建 数据 库 以 后 ， 接 下 来 就 是 创建 数据 表 ， 这 里 以 tb_bb 编程 词典 版 本 信息 表 为 例 ， 讲 解 
如 何 创 建 数据 表 ， 以 及 在 创建 数据 表 的 过 程 中 都 需要 注意 哪些 问题 。 这 里 创建 一 个 名 字 为 tb_bb 的 数 
据 表 ， 包 括 3 个 字段 ， 如 图 2.20 所 示 。 


钼 在 数据 库 db_bcty365 中 创建 一 个 新 表 


Number offiel(s:[3  ) 


输入 新 表 名 称 输入 新 表 字 段 个 数 


图 2.20 创建 tb_bb 数据 表 
单 击 “ 执 行 ” 按 钮 后 ， 进 入 到 如 图 2.21 所 示 的 添加 字段 信息 的 页 面 中 ， 在 此 处 对 字段 进行 详细 的 


设置 ， 包 括 字段 名 、 数 据 类 型 、 长 度 / 值 、 属 性 、 默 认 值 、 额 外 、 主 键 和 索引 等 。 


本 
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困 服务 器 : localhost ， 号 数据 库 : db_bcty365 ， 国 表 :tb_bb 


字段 类 型 回 长 度 上 曹 :1 Null ENG 设置 主键 
加 INT | ho nmotnul 司 -一 nm 司 le 


人 


bbname varcHAR “ 司 Foo ntnull “I 可 


ereatetime [oArerwE 司 [ [nanw 司 [ 
RE 
C [ms 可 D> ab232chineseel 7 
图 2.21 添加 数据 表 中 字段 信息 


六 技巧 : 创建 数据 库 中 的 数据 表 时 ， 字 段 名 的 设计 尽量 要 与 数据 表 的 内 容 相符 合 ， 这 样 有 助 于 程序 


后 期 维护 和 修改 工作 的 进行 ， 能 够 直观 地 看 出 数据 表 的 作用 。 

如 果 使 用 AppServ 配置 PHP 开发 环境 , 那么 在 创建 数据 表 时 不 需要 指定 数据 表 类 型 和 编码 
格式 ; 如 果 使 用 自行 配置 的 PHP 开发 环境 ， 那么 就 要 指定 数据 表 的 类 型 为 MyISAM 和 字 
符 的 编码 格式 为 gb2312_chinese_ci， 否 则 创建 的 数据 表 类 型 为 InnoDB， 而 编码 格式 为 
latin1_swedish_ci, 将 导致 该 数据 表 中 的 数据 拷贝 到 其 他 机 器 上 不 可 用 ， 并 且 数 据 表 中 的 数 
据 出 现 乱码 。 

在 创建 数据 表 的 过 程 中 ， 一 定 要 为 数据 表 指 定 一 个 主键 ， 它 是 数据 表 的 一 个 唯一 的 标识 。 


掌握 数据 表 的 创建 方法 后 ， 就 可 以 自行 创建 数据 表 。 由 于 本 案例 中 涉及 的 数据 表 有 17 个 之 多 ,这 
里 不 能 对 每 个 数据 表 的 功能 设计 进行 一 一 介绍 ， 所 以 只 给 出 几 个 重要 的 数据 表 的 设计 效果 图 供 广大 读 
者 参考 ， 其 他 数据 表 请 参见 本 书 附 带 的 光盘 。 数 据 表 的 设计 结构 如 图 2.22~ 图 2.24 所 示 。 


(1) tb_user (注册 用 户 信息 表 ) 


注册 用 户 信息 表 主 要 用 于 存储 本 社区 中 会 员 的 个 人 信息 。 该 数据 表 的 结构 如 图 2.22 所 示 。 


胃 服务 器 : localhost ， 电 数据 库 : db_bcty365 ， 国 表 :tb_user 


字段 整理 尾 性 Null 默认 笑 外 说 明 
i int(8) 否 auto_increment 自动 编号 ID 
usernc varchar(50) gb2312_chinese_ci 是 NULL 注册 用 户 各 
truename varchar(50) gb2312_chinese_cl 是 NULL 真实 姓名 
pwd varchar(50) gb2312_chinese_ci 是 NULL 注册 密码 
email varchar(50) 。 gb2312_chinese_cl 是 。 NULL 有 效 地 箱 地 址 
SeX varchar(2) gb2312_chinese_cl 是 WNULL 性 别 
tel varchar(20) 。 gb2312_chinese_ci 是 WULL 联系 电话 
虽 varchar(20) 。 9b2312_chinese_cl 是 NULL 9 号码 
address varchar(100) gb2312_chinese_ci 是 NULL 联系 地 址 
logintimes Int) 要 访问 次 数 
Tegtime datetime 否 注册 时 间 
lastlogintime = datetime 否 最 后 一 次 登录 时 间 
四 varchar(20) 。 gb2312_chinese_ci 否 I? 地 址 
h varchar(20) gb2312_chinese_ci 是 NULL 邮政 编码 
usertype int?) 要 用 户 类 型 
question Yarchar(200) gb2312_chinese_ci 否 窜 码 提示 问题 
answer Yarchar(200) gb2312_chinese_ci 要 密码 提示 答案 
truepwd varchar(200) gb2312_chinese_ci 否 真实 灾 码 
photo varchar(50) 。 gb2312_chinese_ci 否 表情 图 
pubtimes int(4) 是 0 发 帖 次 数 


2.22 注册 用 户 信息 表 结 构 
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(2) tb_reply( 论 坛 回帖 信息 表 ) 


论坛 回帖 信息 表 主 要 用 于 存储 登录 会 员 在 本 社区 中 国 
所 示 。 
困 服务 器 : localhost ， 昌 数据 库 : db_bcty365 》 国 表 :tb_reply 


字段 类 型 
过 int(8) 
userid int(8) 
bbsid int(8) 
title Yarchar(200) 


content mediumtext 
createtime datetime 
mark int(2) 
photo Yarchar(80) 


复 帖 子 的 信息 。 该 数据 表 的 结构 如 图 2.23 


整理 尾 性 Null 默认 说 明 
否 auto_increment ”自动 编号 ID 
否 串 辽 注册 用 户 ID 
否 避 殉 发 布 帖子 表 ID 
gb2312_chinese_ci 是 WULL 回复 主题 
gb2312_chinese_ci 是 WULL 回复 内 容 
是 WULL 回复 时 间 
是 NULL 回复 记录 
gb2312_chinese_ci 是 WULL 回复 图 片 


图 2.23 论坛 回帖 信息 表 结 构 


(3) tb_bccd (编程 词典 信息 表 ) 


编程 词典 信息 表 主 要 用 于 存储 本 社区 的 在 线 计 


结构 如 图 2.24 所 示 。 


加 服务 器 : localhost ， 电 数据 库 : db_bcty365 ， 国 表 :tb_bccd 


字段 类 型 
这 int(8) 
bccdname Yarchar(200) 
Owner varchar(100) 
typeid Yarchar(50) 
content mediumtext 
Samepart mediumtext 
addtime datetime 
imageaddress varchar(100) 
bbid int(8) 
price loat 


[ 购 模块 中 出 售 的 编程 词典 的 基本 信息 。 该 数据 表 的 


整理 尾 性 Null 默认 说 明 

否 auto_increment ”自动 编号 ID 

gb2312_chinese_ci 否 编程 词典 名 称 

gb2312_chinese_ci 否 开发 者 

gb2312_chinese_cl 否 版 本 类 型 

gb2312_chinese_ci 否 编程 词典 简介 

gb2312_chinese_ci 理 软件 共同 点 
否 开发 时 间 

gb2312_chinese_ci 否 界面 存储 地 址 
是 NULL 所 属 版 本 的 ID 
是 NULL 价格 


图 2.24 编程 词典 信息 表 结构 


2.6 ”公共 模块 设计 


2.6.1 ”数据 库 连接 文件 


在 进行 程序 开发 的 过 程 中 ， 有 很 多 地 方 都 涉及 到 数据 库 的 应 用 ， 在 应 用 数据 库 之 前 首先 要 与 数据 
库 建立 连接 ， 因 此 可 以 将 数据 库 的 连接 代码 作为 一 个 公共 文件 进行 存储 ， 在 需要 使 用 数据 库 连 接 文 件 
的 地 方 直接 调用 该 文件 即 可 ， 无 须 重复 编写 相同 的 代码 ， 既 减少 了 代码 的 元 余 ， 也 便于 对 数据 库 连 接 
文件 进行 修改 。 在 本 项 目 中 笔者 将 数据 库 的 连接 代码 存储 于 conn.php 中 。conn.php 文件 的 代码 如 下 : 


。 85。 
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例 程 01 ”代码 位 置 ， 光盘 \TM\02\bcty365\conn\conn.php 


<?php 

© $conn=mysql_connect("localhost","root","root"); ”// 连 接 数 据 库 服 务 器 

@ mysql_select_db("db_bcty365",$conn); // 连 接 指 定 的 数据 库 

目 mysql_query("set names gb2312"); /对 数据 库 中 的 编码 格式 进行 转换 ， 避 免 出 现 中 文 乱码 的 问题 
> 

< 人 代码 贴 二 


@ mysql_ conect0: 连接 MySQL 服务 器 ， 服 务 器 的 用 户 名 为 root， 密 码 为 root。 
@ mysql_ select db(): 用 于 连接 指定 的 MySQL 数据 库 ， 数 据 库 名 为 db_bcty365。 
上 @ setnames gb2312: 指定 数据 库 中 字符 的 编码 格式 为 gb2312。 


成 功 创建 conn.php 文件 后 , 在 需要 进行 数据 库 的 操作 程序 中 , 就 可 以 通过 include 或 者 其 他 包含 语 
句 调 用 conn.php 该 文件 即 可 ， 无 须 在 编写 连接 数据 库 的 程序 代码 。 应 用 include 语句 包含 conn.php 文 
件 的 代码 如 下 : 


<?php 
include ("conn/conn.php"); // 包 含 数 据 库 文件 


72> 


2.6.2 将 文本 中 的 字符 转换 为 HTML 标识 名 


在 输出 数据 库 中 数据 的 过 程 中 ， 有 必要 将 数据 中 的 一 些 特 殊 字 符 转换 为 HTML 标识 符 ， 这 样 可 以 
避免 一 些 不 必要 的 麻烦 。 例 如 ， 在 输出 一 个 程序 的 执行 代码 的 过 程 中 ， 如 果 不 对 其 进行 转换 ， 那 么 输 
出 的 将 不 是 程序 的 代码 ， 而 是 程序 的 执行 结果 。 这 里 将 文本 中 字符 的 转换 编写 到 一 个 自 定 义 函 数 
unhtml0 中 ， 保 存 到 function.php 文件 中 ， 将 其 作为 一 个 公共 模块 来 使 用 ， 当 需要 使 用 时 直接 调用 
function.php 文件 即 可 。function.php 文件 包含 两 个 自 定 义 函 数 , 即 unhtml0 函 数 和 msubstr0 函 数 ,unhtml0 
函数 用 于 将 数据 中 的 特殊 字符 转换 为 HTML 标识 符 ; msubstr0) 函 数 用 于 对 字符 串 进 行 指定 长 度 的 截取 。 
其 代码 如 下 : 

例 程 02 ”代码 位 置 ， 光盘 \TM\02\bcty365\function.php 


<?php 
function unhtml($content){ // 定 义 自 定义 函数 的 名 称 
© S$content=htmlspecialchars($content); // 转 换文 本 中 的 特殊 字符 
@ $content=str_replace(chr(13),"<br>",$content); 1/ 替换 文本 中 的 换行 符 
$content=str_replace(chr(32),"&nbsp:;",$content); // 蔡 换文 本 中 的 &nbsp; 
$content=str_replace("[_[","<",$content]; // 替 换文 本 中 的 大 于 号 
$content=str_replace(") )",">",$content); // 蔡 换文 本 中 的 小 于 号 
$content=str_replace("|_|"," ",$content); // 蔡 换文 本 中 的 空格 
目 retum trim($content); /删除 文本 中 首尾 的 空格 


} 

// 定 义 一 个 用 于 截取 一 段 字 符 串 的 函数 msubstr() 

function msubstr($str, $start, $len){ //$str 指 的 是 字符 串 ，S$start 指 的 是 字符 串 的 起 始 位 置 ，$len 指 的 是 长 度 
S$strlen=S$start+S$len; // 用 $strlen 存 储 字符 串 的 总 长 度 ( 从 字符 串 的 起 始 位 置 到 字符 串 的 总 长 度 ) 


RS 
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for($i=0;$i<S$strlen,Si++){ // 通 过 for 循 环 语句 ， 循 环 读 取 字符 串 
日 if(ord(substr($str,$i,1))>0xa0){ ”// 如 果 字 符 串 中 首 个 字 节 的 ASCII 序 数值 大 于 0xa0， 则 表示 为 汉字 
Stmpstr.=substr($srt,$i,2); /每 次 取出 两 位 字符 赋 给 变量 Stmpstr， 即 等 于 一 个 汉字 


Sit+; /变量 自 加 1 
jelsef // 如 果 不 是 汉字 ， 则 每 次 取出 一 位 字符 赋 给 变量 $tmpstr 
S$tmpstr.=substr($str,$i,1);} 
} 
Tetum $tmpstr; // 输 出 字符 串 
}2> 
< 人 代码 贴 二 


@ htmlspecialchars(): 将 特殊 字符 转换 成 HTML 格式 ， 而 不 会 将 所 有 字符 都 转换 成 HTML 格式 。 

@ str_replace (): 将 所 有 在 参数 subject 中 出 现 的 search 以 参数 replace 替换 ,参数 &count 表示 替换 字符 串 执行 的 次 数 。 
@ trim(): 删除 字符 串 中 首尾 的 空白 或 者 其 他 字符 。 

@ substr0: 从 指定 的 字符 串 中 按照 指定 的 位 置 截取 一 定 长 度 的 字符 。 


2.7 ”前 台 首页 设计 


当今 
在 网 络 中 
网 站 的 内 


2.7:1 
网 站 
设计 得 非 


的 品牌 形 


回回 轿 图 加 加 加 


上 述 


时 代 , 很 多 人 都 十 分 重视 事物 的 第 一 印象 ,第 一 印象 基本 上 就 决定 对 某 个 事物 的 看 法 和 态度 ， 
更 是 如 此 ， 网 站 给 人 的 第 一 印象 如 果 不 好 ， 那 么 就 会 有 很 多 人 因此 而 不 去 浏览 该 网 站 ， 无 论 
容 是 否 丰富 。 可 以 说 网 站 首页 设计 的 成 功 与 否 直接 影响 着 整个 网 站 的 发 展 。 


前 台 首 页 概述 


首页 是 整个 网 站 的 脸面 ， 既 要 突出 企业 的 形象 ， 又 要 展示 出 网 站 强大 的 功能 。 如 果 网 站 首页 
常 成 功 ， 那 无 疑 是 为 整个 网 站 的 成 功 增添 了 一 个 硅 码 。BCTY365 网 上 社区 首页 的 设计 以 企业 
象 为 基础 ， 全 力 打造 网 站 的 整体 功能 ， 重 点 推出 企业 的 软件 产品 ， 有 具体 内 容 如 下 : 

网 站 菜单 导航 : 包括 首页 、 技 术 支 持 、 在 线 订购 、 社 区 论坛 、 软 件 下 载 、 升 级 下 载 、 购 买 须 
知 、 联 系 我 们 。 

用 户 注册 和 登录 模块 : 实现 用 户 注 册 、 会 员 登 录 、 找 回 密码 和 修改 密码 的 功能 。 

网 站 公告 : 主要 用 于 发 布 社区 中 的 一 些 新 消息 和 重大 事件 。 

编程 词典 模块 : 推广 企业 的 软件 产品 。 

软件 下 载 模块 : 展示 企业 提供 的 适用 版 和 免费 的 软件 产品 。 

常见 问题 模块 : 列举 出 编程 中 常见 问题 的 解决 方案 。 

社区 论坛 模块 : 浏览 社区 论坛 中 的 部 分 帖子 。 

升级 下 载 模块 : 提供 一 些 软件 的 升级 版 本 下 载 。 

内 容 就 是 BCTY365 网 上 社区 首页 中 体现 出 的 内 容 ， 为 了 更 加 直观 地 了 解 网 上 社区 首页 的 设 


计 ， 这 里 先 预览 一 下 社区 首页 ， 该 首页 在 本 书 光盘 中 的 路 径 为 \TM\02\becty365\index.php， 如 图 2.25 


所 示 。 


本 
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网 站 导航 栏 
BCIY365 社 区 网 ， 找 | 


会 员 登 录 栏 新 颖 ， 活 盖 面 广 的 编程 软件 词典 ， 


编程 词典 简介 


l 行 榨 例 化 ， 这 样 就 引入 了 对 象 的 概念 ， 对 象 是 类 进行 实例 
rr 图 上 综合 车 ; 和， , :程序 是 通过 对 和 象 对 类 中 的 属性 和 方法 进行 引用 的 ,类 
Digest 人 Lgorithm 5， 在 90 年 代 初 LIBRARY MANAGE ， 用 中 还 ,一般 情 况 下 ， 程 序 是 通过 对 象 对 
(2007/09/19) aa bs 引 只 是 具备 某 项 功能 的 抽象 模型 ， 实 际 应 用 中 
， 解 密 密 钥 保密 的 方 ， [ 2007-11-05 ] 
求 公开 的 加 密 密 本 


1WD5 的 全 称 是 Message- 
Best 人 Leorill 5， 在 
f 


Yi soal Basic 编 程 间 典 
标准 版 

125.12 元 

明日 科技 


2005-12-05 00:00:00 


” 程序 测试 [2007/11/21] 
a 


。 程序 测试 [2007/11/21] 
eS 。 程序 测试 [2007/11/21] 


2.25 BCTY365 网 上 社区 首页 


BCTY365 网 上 社区 首页 的 设计 看 上 去 很 复杂 ， 有 很 多 个 版 块 组 成 ， 但 实现 的 过 程 非常 简单 。 总 体 
架构 使 用 一 个 2 行 3 列表 格 和 一 个 3 行 3 列 的 表格 ， 将 其 分 隔 成 不 同 的 版 块 ， 然 后 使 用 脚本 语句 从 数 
据 库 中 读 取 数 据 ， 最 后 将 数据 循环 输出 到 页 面 中 ， 其 中 网 站 的 头 尾 文件 使 用 include 包含 语句 调用 。 首 
页 的 框架 结构 如 图 2.26 所 示 。 


S> 
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image (140 x... 


企业 短信 群发 巴 


了 了 
a 


图 2.26 网 站 首页 的 框架 结构 
2.7.2 ”前 台 首 页 技术 分 析 


作为 网 站 首页 ， 不 一 定 要 具有 什么 特殊 的 技术 或 者 功能 ， 应 该 是 以 简捷 、 鲜 明 ， 突 出 企业 形象 ， 
展示 网 站 的 功能 为 主 。 即 使 使 用 的 是 一 个 静态 页 面 ， 只 要 能 够 将 内 容 表达 人 全面、 完整 ， 那 么 这 个 首页 
设计 也 是 非常 成 功 的 。 

在 本 案例 首页 的 设计 中 ， 应 用 到 一 个 文字 循环 滚动 的 技术 ， 通 过 该 技术 来 输出 社区 中 发 布 的 公告 
信息 。 该 技术 是 通过 JavaScript 脚本 和 div 标签 来 共同 实现 的 ， 其 实现 的 原理 是 : 首先 创建 一 个 div 标 
签 ， 然 后 在 div 标签 中 输出 公告 信息 ， 最 后 通过 JavaScript 来 对 div 标签 进行 操作 ， 实 现 div 标签 中 内 
容 的 滚动 输出 。 该 技术 的 实现 在 index.php 页 中 完成 ， 其 中 使 用 的 javascript 脚本 的 代码 如 下 : 

例 程 03 ”代码 位 置 ， 光盘 \TM\02\bcty365\index.php 

<script language="JavaScript"> 


marqueesHeight=222; // 定 义 输出 标签 的 高 度 

stopscroll=false; // 定 义 stopscroll 的 默认 值 为 false 

with(marquees){ /编辑 marquees 标 签 的 属性 
style.width=0; // 定 义 初始 宽 为 0 


style.height=marqueesHeight; /定义 marquees 标 签 的 高 为 222 
89 乡 


PHP 项 目 开发 全 程 实录 


style.overflowX="visible": /定义 值 为 显示 
style.overflowY="hidden"; // 定 义 值 为 隐藏 

noWrap=true; 

‘onmouseover=new Function("stopscroll=true"); // 当 鼠标 经 过 时 执行 stopscroll=true 
‘onmouseout=new Function("stopscroll=false"); // 当 鼠标 离开 时 执行 stopscroll=false 


} 
// 创 建 一 个 新 的 div"templayer" 与 div"marquees" 进 行 连接 ， 实 现 不 间断 的 循环 输出 内 容 
document.write('<div id="templayer" style="position:absolute;z-index:1;visibility:hidden"></div>"); 


preTop=0; currentTop=0; 

function init(){ 
templayer.innerHTML=""; /设置 templayer 的 初始 值 为 空 
while(templayer.offsetHeight<marqueesHeight){ // 判 断 当 templayer 的 高 度 小 于 marquees 的 高 度 时 

templayer.innerHTML+=marquees.innerHTML; // 将 templayer 的 值 赋 给 marquees 

上 
marquees.innerHTML=templayer.innerHTML+templayer.innerHTML; // 将 templayer 的 值 累加 
setInterval("scrollup()",50); /间隔 50 毫 秒 执行 一 次 scrollup() 函 数 

} 

function scrollup(O){ /实现 滚动 输出 
if(stopscroll=—true) retum; /判断 如 果 stopscroll 一 true， 不 执行 循环 
preTop=marquees.scrollTop; 
marquees.scroll Top+=1; 
if(preTop==marquees.scrollTop)!{ 


} 


</script> 

在 div 标签 中 ， 主 要 是 输出 数据 库 中 存储 的 公告 信息 ， 并 且 对 输出 的 信息 进行 截取 和 替换 ， 规 范 
输出 的 内 容 。div 标签 中 的 程序 代码 如 下 : 

<div id=marquees > ”<!--> 创 建 一 个 div 标 签 <!--> 


<table width="200" height="25" border="0" align="center" cellpadding="0" cellspacing="0"> 
<?php // 从 数据 库 中 读 取 公告 数据 


S> 


marquees.scrollTop=templayer.offsetHeight-marqueesHeight; 
marquees.scrollTop+=1; 


$sql=mysql query("select id,title,createtime from tb tell order by createtime desc limit 0,10",$conn); 
S$info=mysql fetch array($sql); 


if($info—false){ // 判 断 当 $info==false 时 执行 下 面 的 内 容 
> 
<tr> 

<td height="25"><div align="center"><a href="#" class="a4"> 本 站 暂 无 公告 发 布 ! </a></div></td> 
</t> 
<?php  }elsef 

Si=1; // 定 义 变量 $i=1 

dof /执行 do..while 循 环 语句 
ey 
<tr> 

<td height="25" style="padding:4"> 

<a href="tellinfo.php?id=<?php echo $infofid];?>" class="al"> 

<?php 


if($i—D){ // 判 断 当 $i==1 时 ,将 输出 的 内 容 设 置 为 红色 
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echo "<font color=red>"; 
} 
echo $i.".&nbsp;"; 
echo unhtml(msubstr($info[title],0,50)); // 应 用 自 定义 函数 对 输出 的 内 容 进行 控制 
if(strlen($info[title])>50){ // 当 输出 内 容 的 长 度 超过 50 个 字符 时 用 "..…" 代 替 
Soho oe 
} 
echo "(".str_replace("-","/",S$info[createtime]).")"; /将 输出 的 公告 时 间 中 的 "-" 用 "/" 替 代 
if($i—1){ echo "</font>"; } 
> </a> 
</td> 
</tr> 
<?php 
Si++; 
}while($info=mysql_fetch_array($sq]l)); /do…while 循 环 语句 结束 


1 
pe 


<hable> 
</div> 
在 首页 中 使 用 深 动 条 是 一 个 比较 不 错 的 方法 ， 通 过 其 可 以 增加 网 页 的 动态 效果 ， 增 加 网 页 的 观赏 
性 ， 而 且 不 会 影响 到 网 页 的 浏览 速度 。 


2.7.3 ”前台 首页 的 实现 过 程 


国 前 台 首页 使 用 的 数据 表 : tb_tell、tb_soft、tb_bccd、tb bb、tb_cjwt、tb_bbs、tb sjxz 

开发 网 站 首页 主要 就 是 连接 数据 库 ， 从 数据 库 中 读 取 数据 ， 最 后 应 用 循环 语句 将 数据 库 中 数据 输 
出 到 前 台 页 面 。 由 于 使 用 的 代码 较 多 ， 而 且 多 数 都 是 重复 使 用 ， 所 以 这 里 只 给 出 首页 中 公告 发 布 模块 
的 代码 。 

公告 发 布 模块 主要 实现 从 数据 库 中 读 取 公 告 数据 ， 将 数据 在 首页 中 滚动 输出 ， 并 且 对 公告 信息 的 
长 度 进行 控制 ， 保 证 内 容 的 整齐 、 规 范 。 具 体 详 细 代 码 可 以 参考 本 书 光盘 中 TM\02\bcty365\index.php 
文件 ，index.php 文件 的 部 分 代码 如 下 : 

例 程 04 ”代码 位 置 ， 光盘 \TM\02\bcty365\index.php 


<?php include_once("top.php"); /获取 头 部 文件 ?> 
…// 省 略 部 分 代码 
<?php 
// 读 取 数 据 库 中 公告 表 中 的 数据 
$sql=mysql_query("select id,title,createtime from tb_tell order by createtime desc limit 0,10",$conn); 
$info=mysql_fetch_array($sql); // 执 行 读 取 数据 表 中 数据 的 语句 
if($info—false){ // 如 果 返 回 值 为 空 则 执行 下 面 的 语句 
es 
<tr> 
<td height="25"><div align="center"><a href="#" class="a4"> 本 站 暂 无 公告 发 布 ! </a></div></td> 
</tr> 
<2php 


本 


PHP 项 目 开发 全 程 实录 


jelsef // 如 果 返 回 值 不 为 空 则 执行 下 面 的 do.…while 循 环 语句 
$i=1; 
dof 
?> 
<tr> 
<td height="25" style="padding:4"><a href="tellinfo.php?id=<?php echo $info[id];?>" class="al"> 
<?php 
if($i—1){ // 判 断 当 变量 $i=1 时 ， 输 出 的 内 容 以 红色 字体 显示 
echo "<font color=red>"; 
} 
echo $i.".&nbsp;"; 
oo echo unhtml(msubstr($info[title],0,50)); 
© if(strlen($info[title])>50){ // 如 果 标 题 长 度 大 于 50 个 字符 ， 则 以 省 略 号 代替 


eo 
bl 
© echo "(".str_replace("-","/",$info[createtime]).")"; // 输 出 公告 发 布 的 时 间 ， 并 且 将 其 中 的 "" 使 用 "-" 替 换 
if($i=—=1){ 
echo "</font>"; 


<?php 
Sit+t; // 变 量 自 加 1 
}while($info=mysql_fetch_array($sql); //do…while 循 环 语句 结束 


} 

> 
// 省 略 了 部 分 代码 
<?php 

include_once("bottom.php"); /调用 网 站 的 尾 文件 
> 


< 代码 贴 十 
@ 应 用 unhtml0 和 msubstr() 自 定义 函数 去 除 输出 字符 串 中 的 空格 和 控制 输出 字符 串 的 长 度 。 
@ stlen0: 获取 指定 字符 串 的 长 度 。 
@ str_replace(): 实现 字符 囊 的 替换 。 


2.8 注册 模块 设计 
2.8.1 注册 模块 概述 
BCTY365 网 上 社区 系统 为 了 更 好 地 与 广大 网 民 朋友 进行 交流 和 沟通 ， 创 建 了 一 个 会 员 注册 模块 。 


通过 会 员 注册 模块 ， 可 以 有 效 地 对 用 户 信息 进行 采集 ， 并 将 合法 的 用 户 信息 保存 到 指定 的 数据 表 中 ， 
实现 与 用 户 的 长 期 沟通 和 交流 。 既 然 设置 了 会 员 注册 模块 ， 那 么 在 系统 中 就 要 为 会 员 提供 一 些 特殊 的 


Se 
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权限 。 在 本 系统 中 注册 会 员 可 以 拥有 如 下 权限 : 在 本 社区 的 论坛 中 发 布 和 回复 帖子 ， 在 技术 支持 模块 
中 发 表 留 言 ; 在 升级 下 载 模块 中 下 载 软件 升级 包 等 ， 而且 可 以 进行 修改 密码 和 找 回 密码 。 用 户 注册 模 
块 的 运行 结果 如 图 2.27 所 示 。 
您 已 经 成 功 的 申请 了 本 站 的 用 户 名 : HP 程序 员 如 果 注 册 为 本 站 的 用 户 ， 您 还 应 该 填写 以 下 信息 ? 
注意 : 以 下 注册 信息 均 为 必 添 内 容 9 


真实 姓名 : 了 
性 别 : [Ems| 
邮箱 地 址 : 。 dasina eom ”| (为 了 便于 工作 人 员 与 你 联系， 请 填写 正确 的 E-nsil 地 址 ? ) 
联系 电话 : [EY EE 
邮编 : 130025 (时 编 只 能 由 数字 组 成 ， 并 且 为 6 位 !) 
Q9 号 码 : fem (gg 号 只 能 由 数字 组 成 !) 
家 庭 性 址 : FE 和 
头 你 选择 : [4sif 辐 Ea 
密码 保护 问题 : 休闲 运 动 是 什么 ? 可 
您 的 答案 : 打 羽 毛 球 (了 能 够 找 加 丢失 的 密码 ,请 记 住 该 答案 4 ) 
效 验 码 : Bsr 5861 


提交 注册 信息 重新 填写 注册 信息 
图 2.27 用 户 注册 模块 的 运行 结果 


2.8.2 ”注册 模块 技术 分 析 


在 会 员 注册 模块 中 ， 必 不 可 少 的 就 是 要 对 用 户 输 入 的 信息 进行 判断 ， 首 先 判断 用 户 填 写 的 注册 信 
息 中 哪些 是 必须 填写 的 ， 哪 些 可 以 不 填写 ， 然 后 进一步 判断 输入 的 信息 是 否 合理 合法 ， 例 如 ， 判 断 输 
入 的 邮编 的 格式 是 否 正 确 ， 判 断 输入 邮箱 的 格式 是 否 正确 等 。 对 表单 中 提交 数据 进行 判断 最 常用 的 办 
法 就 是 使 用 JavaScript 脚本 ， 也 可 以 使 用 正则 表达 式 。 下 面 讲 解 在 本 模块 中 是 如 何 通 过 JavaScript 实现 
表单 提交 数据 验证 。 

操作 原理 是 : 在 form 表单 中 调用 onsubmit 事件 ， 通 过 该 事件 调用 指定 的 JavaScript 脚本 ， 执 行 
chkinput() 自 定义 函数 ， 实 现 对 表单 中 提交 数据 的 验证 。 在 JavaScript 脚本 中 ， 实 现 对 表单 中 提交 数据 
进行 判断 ， 判 断 输入 的 内 容 是 否 为 室 ， 判 断 内 容 的 格式 是 否 正确 ， 如 果 正 确 则 继续 执行 ， 否 则 将 弹出 


提示 对 话 框 ， 并 将 鼠标 的 焦点 指定 到 出 错 的 位 置 。 具 体 的 JavaScript 脚本 代码 如 下 : 
<script language="JavaScript" type="text/javascript"> 
function chkinput(form){ // 定 义 一 个 函数 
if(form.tel.value—""){ // 浏 断 te 文本 框 中 的 值 是 否 为 空 
alert(" 请 填写 联系 电话 !"); /如 果 为 空 则 输出 "请 填写 联系 电话 !" 
form.tel.select(); // 返 回 到 tel 文 本 框 
retum(false); 
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} 

if(form.email.value—"™"){ /判断 email 文 本 框 的 值 是 否 为 空 
alert(" 请 输入 E-mail 地 址 1"); // 如 果 为 空 则 输出 "请 输入 E-mail 地 址 " 
form.email.select(); // 返 回 到 email 文 本 框 
retum(false); 

} 


var i=form.email.value.indexOf("(@"); 
var j=form.email.value.indexOf("."); 


// 进 一 步 判 断 邮箱 的 格式 是 否 正确 ,是 否 包 含 "@" 和 "." 


if(Gi<O)j>0)G<0){ 
alert(" 请 输入 正确 的 E-mail 地 址 1"); 
form.email.select(); // 返 回 到 email 文 本 框 
retum(false); 

} 

return(true); /提交 表单 
} 
</script> 


上 述 代码 中 ， 只 是 列举 了 JavaScript 中 的 部 分 内 容 ， 并 且 在 对 电话 号 码 进行 判断 时 ， 只 是 判断 其 是 
和 否 为 室 ， 没 有 进一步 判断 电话 号 码 的 格式 是 否 正确 。 如 果 想 要 更 加 准确 地 判断 电话 号 码 的 格式 是 否 正 
确 可 以 采用 下 面 的 方法 : 通过 正则 表达 式 的 preg_match(0) 函 数 ， 在 表单 提交 处 理 页 中 对 电话 号 码 进行 
判断 。 
preg_match0) 函 数 的 语法 格式 如 下 : 
int preg_match ( string pattern, string subject [, array matches [, int flags]] ) 
preg_match() 函 数 的 参数 说 明 如 表 2.3 所 示 。 
表 2.3 preg_match() 函 数 的 参数 说 阴 
参数 说 阴 
Pattern 必要 参数 。 需 要 匹配 的 正则 表达 式 
Subject 必要 参数 。 输 入 的 字符 串 


bee 可 选 参数 。 输 出 的 搜索 结果 的 数组 ， 如 Sout[0] 将 包含 与 整个 模式 匹配 的 结果 ，$out[1] 将 包含 与 第 一 个 捕 
获 的 括号 中 的 子 模式 所 匹配 的 结果 ， 依 次 类 推 

Flags 可 选 参数 。 标 记 : PREG_OFFSET_CAPTURE， 对 每 个 出 现 的 匹配 结果 也 同时 返回 其 附属 的 字符 串 偏 移 
量 ， 本 标记 自 php 4.3.0 起 可 用 


通过 preg_match() 函 数 判 断 电话 号 码 的 格式 是 否 正确 的 方法 如 下 : 首先 定义 一 个 用 于 判断 电话 号 码 
格式 的 正则 表达 式 。 代 码 如 下 : 
/0d{3})0d{8D)S0d{4})0 {7 SP Nd{4)0d{8)s/ 
正则 表达 式 的 功能 分 析 如 下 : 使 用 “^” 和 “$” 对 字符 串 进行 边界 的 限制 ， 对 区 号 从 字符 串 的 开 
始 进行 匹配 ， 对 其 他 号 码 从 字符 串 的 末尾 开始 进行 匹配 ; 将 括号 “0” 中 的 内 容 作为 一 个 原子 使 用 ; 使 
用 “\d” 来 匹配 一 个 数字 ， 区 号 为 3 或 4 个 数字 ， 其 他 数字 为 7 或 8 个 ; 使 用 “{}” 来 对 前 字符 进行 重 
pe 使 用 “|” 对 匹配 的 模式 进行 选择 ， 分 成 3 个 模式 。 


RS 
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然后 将 该 正则 表达 式 应 用 到 preg_match() 函 数 中 ,对 表单 提交 的 电话 号 码 进行 判断 ,如 果 正 确 则 继 
续 执行 ， 否 则 弹出 提示 信息 ， 并 返回 到 表单 提交 页 。 代 码 如 下 : 
<2php 
Stel="0431-84978981"; // 定 义 一 个 电话 号 码 的 变量 
if(preg match(wACd {3}- )\d{8))sQd{4}-)0d{7))8I"Qd{4}-)N\d{8})S "Nd{11})8/",Stel,Scounts) { 
echo "您 输入 的 电话 号 码 格式 正确 !"; /输出 字符 串 
jelsef 
echo "<script>alert(' 您 输入 的 电话 号 码 的 格式 不 正确 !!);history.back()</script>"; 


} 
?> 


2.8.3 ”注册 模块 的 实现 过 程 


国 ”注册 模块 使 用 的 数据 表 : tb_user 

注册 模块 的 实现 过 程 非常 简单 ， 首 先 阅 读 注册 服务 条 款 ， 然 后 填写 用 户 注册 的 用 户 名 和 密码 ， 提 
交 后 由 系统 判断 输入 的 用 户 名 是 否 被 占用 ， 如 果 未 被 占用 则 可 以 继续 注册 ， 填 写 详细 的 注册 信息 ， 将 
数据 提交 到 表单 处 理 页 进行 处 理 ， 最 后 将 用 户 注册 的 信息 保存 到 指定 的 数据 表 中 。 用 户 注册 模块 的 实 
现 过 程 主要 由 3 个 文件 完成 : register.php 用 于 输出 注册 服务 条 款 ， 以 及 填写 注册 的 用 户 名 和 密码 ， 并 
且 判 断 注册 的 用 户 名 和 密码 是 否 被 占用 ;， getuserinfo.php 文件 用 于 填写 详细 的 注册 信息 ， 并 且 在 表单 中 
应 用 数字 验证 码 技术 ; savereginfo.php 文件 用 于 对 表单 中 提交 的 数据 进行 处 理 , 将 数据 保存 到 指定 的 数 
据 表 中 。 

在 savereginfo.php 文件 中 ， 首 先 连接 数据 库 ， 然 后 获取 到 表单 中 提交 的 数据 ， 并 且 判 断 提交 的 用 
名 是 否 被 占用 ， 最 后 将 提交 的 数据 进行 处 理 ， 并 将 数据 保存 到 指定 的 数据 表 中 。 程 序 代码 如 下 : 

例 程 05 ”代码 位 置 ， 光 盘 \TM\02\bcty365\saverreginfo.php 


<?php session_start(); // 初 始 化 session 变 量 
include_once("conn/conn.php"); // 连 接 数 据 库 
Susernc=trim($_POST[usernc]); /获取 注册 的 用 户 名 

// 判 断 指定 的 用 户 名 是 否 存 在 

$sql=mysql_query("select usemce from tb_user where useme=".$usernc."",$conn); 
Sinfo=mysql_fetch_array($sql); // 按 指定 条 件 检索 数据 信息 
if($info!=false){ /如 果 查 询 结果 不 为 室 ， 则 执行 以 下 操作 


echo "<script language='javascript>alert(' 对 不 起 ， 该 昵称 已 被 其 他 用 户 使 用 !):history.back(0;</script>"; 
exit; 
} 
$xym=trim($_POST[xym]); /去 除 变量 两 边 的 空格 
$num=$_POST[num]; // 接 收 变量 值 
if(strval($xym)!=strval($num)){ 
echo "<script>alert(' 验 证 码 输入 错误 !");window.location.href='register.php';</script>"; 
exit;} 


// 对 表单 提交 的 数据 进行 处 理 

Struepwd=trim($_POST[pwd1]); /获取 真实 密码 
Spwd=md5($truepwd); /获取 加 密 密 码 
S$truename=trim($_POST[truename]); /获取 真实 姓名 


Semail=trim($_POST[email]); /获取 邮 箱 地 址 
95 。 多 
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S$sex=$_POST[sex]; // 获 取 性 别 
Stel=trim($_POST[tel]): /获取 电话 
S$yb=trim($_POST[yb]); /获取 邮政 编码 
S$qq=trim($_POST[qq]); /获取 QQ 
$address=trim($_POST[address]); /获取 地 址 
$question=trim($_ POST[question]); /获取 提示 问题 
$answer=trim($_POST[answer]); /获取 问题 答案 
S$ip=getenv("REMOTE_ADDR"); // 获 取 客 户 端 的 IP 
Slogintimes=1; // 指 定 访问 次 数 
S$regtime=date("Y-m-j H:i:s"); // 获 取 时 间 
S$lastlogintime=$regtime; 

S$usertype=0; // 指 定 用 户 类 型 ,默认 为 0 
$photo=$_POST["photo"]; /获取 头像 

/将 表单 中 提交 的 数据 存储 到 数据 表 中 


if(mysql_query("insert into 


tb user(usernc,truename,pwd,email,sex,tel,qq,address,logintimes,regtime,lastlogintime,ip,usertype,yb,question,answer,truepwd, 
photo) 
values('$usemnce','$truename','$pwd',$email’,'$sex','$tel','$qq','$Saddress','$logintimes','$regtime’,'$lastlogintime','$ip','$usertype','$ 
yb','$question','$answer','$truepwd','$photo")", $conn)){ 


session register("unc"); 
$ SESSION[T"unc"]=$usernc; 


echo "<script>alert(' 注 册 成 功 !");window.location.href='index.php';</script>"; 


}else{ 


// 如 果 添 加 操作 失败 ， 则 给 出 提示 


echo "<script language='javascript>alert( 对 不 起 ,注册 失败 !");history.back();</script>"; 


exit; 


2.9 ”技术 支持 模块 设计 


// 退 出 


技术 支持 模块 主要 是 从 浏览 者 的 角度 进行 设计 ， 存 储 大 量 技术 问题 的 解决 方案 数据 ， 为 浏览 者 查 
阅 提供 方便 ， 而 且 设计 一 个 企业 与 客户 沟通 的 平台 ， 能 够 随时 了 解 客户 或 者 会 员 的 意见 和 需求 。 


2.9.1 技术 支持 模块 概述 


技术 支持 模块 主要 由 3 个 子 模块 组 成 ， 包 括 常 见 问 题 、 客 户 反馈 和 联系 方式 。 常 见 问题 模块 主要 
用 于 展示 编程 中 一 些 常 见 问题 的 解决 方案 或 者 方法 ， 为 浏览 者 解决 编程 中 的 疑难 问题 提供 方便 ;客户 
反馈 模块 主要 用 于 收集 和 获取 来 自 客户 的 需求 和 意见 ， 联 系 方式 模块 主要 用 于 展示 企业 的 形象 和 具体 


2.9.2 ”技术 支持 模块 技术 分 析 


技术 支持 模块 中 在 对 常见 问题 解决 方案 的 数据 进行 输出 时 ， 使 用 了 分 页 处 理 技术 ， 该 技术 的 设计 
思路 是 : 从 数据 库 中 读 取 数 据 ， 获 取 数 据 总 量 ， 在 每 页 中 显示 20 条 数据 ， 根 据 数据 总 量 和 每 页 显示 的 


心中 征 
Sa 


第 2 章 BCTY365 网 上 社区 (Apacher+PHP+phpMyAdmin+MySQL 5.0 实现 ) 


条 数 对 数据 进行 分 页 处 理 ， 计 算出 有 多 少 页 和 当前 显示 的 页 码 ， 实 现 首页 、 上 一 页 、 下 一 页 和 尾 页 之 
间 的 页 面 跳 转 。 具体 的 设计 思路 可 以 参考 cjwt.php 文件 中 的 代码 注释 和 代码 贴 士 。 cjwt.php 文件 的 程序 


代码 如 下 : 
例 程 06 ”代码 位 置 ， 光盘 \TM\02\bcty365\cjwt.php 
<?php 
$sql=mysql_query("select count(*) as total from tb_cjwt",$conn); // 读 取 数 据 库 中 数据 
$info=mysql_fetch_array($sql); /返回 数据 
@ Stotal=$infoftotal]; 
// 判 断 字段 total 是 否 为 空 ， 为 空 则 执行 下 面 的 内 容 
if($total==0){ 
?> 
<tr> 
<td height="22" colspan="2"><div align="center"> 对 不 起 ， 暂 无 常见 问题 '</div></td> 
</t> 
<?php 
}else{ /如 果 不 为 室 ， 则 执行 下 面 的 内 容 
@ if(!isset($_GET["page"]) | !is_numeric($_GET["page"]))!{ // 判 断 $_GET 获 取 的 page 的 值 是 否 存 在 
日 Spage=1; /如 果 不 存 在 ， 则 设置 变量 的 值 为 1 
}elsef 
Spage=intval($_GET["page"]); // 如 果 存 在 ， 则 获取 变量 $_GET 的 值 
} 
/设置 变量 $pagesize, 每 页 显示 的 数据 数据 量 为 20 
目 Spagesize=20; 
if($total% $pagesize—0){ /如 果 变 量 的 值 为 0 
© Spagecount=intval($total/$pagesize); // 获 取 变 量 的 整数 值 
Yelsef 
@ S$pagecount=ceil($total/$pagesize); // 如 果 不 为 0 则 获取 实际 的 整数 值 
// 读 取 数 据 库 中 数据 ， 按 照 时 间 进 行 降 罕 排 列 
$sql=mysql query("select * from tb cjwt order by createtime desc limit ".($page-1)*$pagesize.",$pagesize 
",$conn); 
while($info=mysql fetch array($sql))! 
> 
2 // 省 略 部 分 代码 
<table width="600" height="25" border="0" align="center" cellpadding="0" cellspacing="0"> 


<tr> 
<td width="479"><div align="left">&nbsp;&nbsp; 共 有 常见 问题 &nbsp;<?php echo $total:?>&nbsp: 条 &nbsp; 


每 页 显示 &nbsp;<?php echo $pagesize;?>&nbsp; 条 &nbsp; 第 &nbsp;<?php echo $page;?>&nbsp; 页 / 共 &nbsp;<?php echo 
$pagecount;?>&nbsp; 页 </div></td> 


<td width="269"><div align="right"> 
<a href="<?php echo $_SERVERI"PHP_SELF"]?>?page=1" class="al"> 首 页 </a>&nbsp; 
<a href="<?php echo $ SERVER["PHP SELF"]?>?page=<?php 


if($page>1) // 判 断 如 果 页 码 大 于 1 
echo $page-1; /| 输出 前 一 页 

else 
echo 1; 


?>" class="al"> 上 一 页 </a>&nbsp; 
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<a href="<?php echo $_ SERVER["PHP_SELF"]?>?page=<?php 


if($page<$pagecount) // 如 果 页 码 小 于 总 页 数 
echo $paget+l; 

else 
echo $pagecount; /| 输出 下 一 页 


?>" class="al"> 下 一 页 </a>&nbsp; 
<a href="<?php echo $_SERVER["PHP SELF"]?>?page=<2?php echo $pagecount;?>" class="al"> 尾 页 
</a>&nbsp;&nbsp;</div> 
</td> 
</tr> 
</table> 


Ah 代码 由 二 
@ $total: 为 数据 库 中 数据 总 的 记录 数 。 
@ isset0: 检测 变量 是 否 已 经 设置 ; is_numeric() 检 测 变量 是 否 为 数字 或 者 数字 字符 串 。 
@ $page: 变量 为 页 码 中 的 第 几 页 。 
@ intval0: 获取 变量 的 整数 值 . 
@ $pagesize: 表示 在 每 页 中 显示 多 少 条 数据 。 
@ $pagecount: 表示 所 有 的 数据 可 以 分 成 多 少 页 。 
@ ceil(): 获取 变量 中 的 整数 值 ， 这 里 用 于 获取 页 码 的 整数 值 。 
@S$ SERVER["PHP_SELF"]: 服务 器 变量 ， 这 里 用 于 获取 网 页 的 链接 地 址 。 


2.9.3 ”常见 问题 的 实现 过 程 


国 ”常见 问题 使 用 的 数据 表 : tb_cjwt 
常见 问题 子 模块 实现 的 主要 功能 是 展示 出 数据 库 中 存储 的 有 关 编 程 中 遇 到 的 常见 问题 及 解决 方 
案 。 其 运行 结果 如 图 2.28 所 示 。 
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问题 : 如 何 解决 输出 数据 库 中 数据 乱码 的 问题 ? 


在 连接 数据 库 的 文件 中 , 指定 数据 库 中 数据 的 编码 格式 为 "gb2312” 
这 里 连接 一 个 用 户 名 为 root, 密码 为 root 的 数据 库 服务 器 , 指定 连接 的 数据 库 为 4b_root, 并 且 指定 数据 库 
中 编码 格式 为 eb2312. 
《php 
解 答 : $comm=mysql_connect ("localhost", "root”, "root"); 
mysql_select_db ("db_root”, $conn) 
mysql_query ("set names gb2312"); 
9 


过 该 方法 , 就 可 以 避免 在 输出 数据 库 中 的 数据 时 出 现 乱码 


通 ; 
图 2.28 常见 问题 模块 的 运行 结果 
该 模块 由 两 个 文件 组 成 , 一 个 是 cjwt.php 文件 , 用 于 存储 创建 问题 数据 , 详细 内 容 可 以 参考 2.9.2 节 ; 
另 一 个 是 lookcjwtphp 文件 ， 用 于 输出 cjwt.php 文件 中 对 应 问题 的 详细 介绍 和 解决 方案 。 其 代码 如 下 : 
例 程 07 ”代码 位 置 ， 光盘 \TM\02\bcty365\lookcjwt.php 
<?php 


include_once("conn/conn.php"); // 与 数据 库 建立 连接 
\ .98 。 
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include_once("function.php"); // 调 用 自 定义 函数 
// 读 取 tb_cjwt 表 中 的 数据 ,条 件 为 :d="$_GET[id]" 

$sql=mysql_query("select * from tb_cjwt where id=".$_GET["id"]."",$conn); 
$info=mysql_fetch_array($sql); 


2> 
<table width="635" height="100" border="0" align="center" cellpadding="0" cellspacing="0"> 
<tr> 
<td width="94" height="30"><div align="center"><strong> 问 &nbsp;&nbsp; 题 : </strong></div></td> 
<td width="541"><?php echo unhtml($info["question"]); // 输 出 问题 的 详细 内 容 ?></td> 
</tr> 
<tr> 
<td height="70"><div align="center"><strong> 解 &nbsp;&nbsp; 答 : </strong></div></td> 
<td height="70">&nbsp;<?php echo unhtml($info["answer"]); // 输 出 问题 的 解决 方案 ?></td> 
</tr> 
</table> 


2.9.4 客户 反馈 的 实现 过 程 


国 客户 反馈 使 用 的 数据 表 : tb_user、tb leaveword 
客户 反馈 子 模块 为 客户 提供 一 个 反馈 意见 和 提出 要 求 的 平台 , 并 且 将 提交 的 信息 存储 到 数据 库 中 。 
其 运行 结果 如 图 2.29 所 示 。 


(四 技术 支持 > 常见 问题 客户 反馈 联系 方式 


主题: 隐 程 河 典 什么 时 候 可 以 上 市 
类 别 : 我 的 留言 可 


请 问 你 们 的 编程 词典 什么 时 候 可 以 上 市 ? “< 
内 容 : 
| 
效 验 码 ; RE ED 重 写 


图 2.29 客户 反馈 模块 的 运行 结果 
该 功能 只 对 本 网 站 中 的 会 员 开 通 ， 即 只 有 以 会 员 身份 登录 的 用 户 才 具 有 反馈 信息 的 权限 ， 其 中 在 
对 提交 表单 的 细节 处 理 上 使 用 JavaScript 脚本 来 验证 表单 中 的 值 是 否 为 空 ， 而 且 还 使 用 数字 验证 码 技 
术 。 对 表单 中 提交 的 数据 进行 处 理 是 在 saveleaveword.php 文件 中 完成 ， 该 文件 主要 用 于 对 表单 中 提交 
的 数据 进行 处 理 ， 将 数据 存储 到 数据 库 中 。 其 代码 如 下 : 
例 程 08 ”代码 位 置 : 光盘 \TM\02\bcty365\saveleaveword.php 


<?php session_start(); // 初 始 化 一 个 session 变 量 
$xym=$_POST[xym]; // 获 取 $_POST 提 交 的 值 
if($xym!=$_SESSION["autonum"])!{ // 判 断 验 证 码 是 否 正确 


echo "<script>alert(' 效 验 码 输入 错误 1");history.back();</script>"; 


exit; 
»*99.， Gg 
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} 

Stitle=$_POST["title"]; /获取 反馈 信息 的 标题 
Scontent=$_POST["content"]; // 获 取 反 馈 信息 的 内 容 
Stype=$_POST["type"]; /获取 反馈 信息 的 类 型 
include_once("conn/conn.php"); /| 与 数据 库 建立 连接 
S$sql=mysql_query("select id from tb_user where usemc=".$_SESSION["unc"]."",$conn); // 读 取 数 据 库 中 数据 
$info=mysql_fetch_array($sql); // 获 取 结 果 集 中 的 数组 
$userid=$info["id"]; 

/向 数据 库 中 添加 数据 


if(mysql_query("insert into tb_leaveword(userid,type,title,content,createtime) 
values('$userid','$type','S$title','$content',".date("Y-m-j H:i:s").")",$conn){ 
echo "<script>alert(' 留 言 发 表 成 功 !");history.back();</script>"; // 添 加 操作 成 功 ， 给 出 提示 信息 
}else{ 
echo "<script>alert(' 留 言 发 表 失败 !);history.back();</script>"; // 添 加 操作 失败 ， 给 出 提示 信息 
B 


?> 


2.9.5 ”单元 测试 


在 对 客户 反馈 模块 进行 测试 的 过 程 中 ， 当 提交 反馈 信息 时 ， 提 示 “ 客 户 反 馈 发 表 失 败 ! ”。 经 过 
初步 的 判断 ， 问 题 可 能 出 现在 向 数据 库 添加 数据 的 过 程 中 。 为 进一步 查找 出 问题 的 根源 ， 在 
saveleaveword.php 页 中 应 用 了 mysql_error() 函 数 ， 该 函数 可 获取 详细 的 错误 信息 ,将 它 放 置 在 insert 添 
加 语句 之 后 ， 然 后 重新 运行 网 页 ， 运 行 结果 如 图 2.30 所 示 。 

191x 
文件 中 编辑 F) 查看 WW) 收藏 从 工具 E) 帮助 


地址 人 @) | 和 http: //192. 168. 1.59/mr/bety365/saveleaveword 问 


图 2.30 应 用 mysql_error() 函 数 获取 的 错误 信息 


在 该 结果 图 中 可 以 看 出 是 数据 表 中 的 type 字段 出 了 问题 , 经 过 仔细 检查 发 现 , 原来 是 在 编写 insert 
添加 语句 的 过 程 中 ， 将 语句 中 字段 的 排列 顺序 与 对 应 的 字段 值 的 顺序 弄 错 了 ， 如 图 2.31 所 示 。 


if (mysql_query("insert into tb_leaveword(userid, type, title, content, createtime) 
Values ( $us' Dontent’,’". date("Y-m-j H:i:s").”’)", $comm)){ 


echo “<script>alert ("留言 发 表 成 功 ! *) ;hi 
颠倒 $title 和 $type 的 顺序 


story. back () ;</s 
lelse{ 
echo "<script>alert( 留言 发 表 类 败 ! ”);history. back() ;</script>》"; 


图 231 代码 中 的 错误 截图 


调整 变量 $title 和 S$type 的 顺序 ， 重 新 运行 程序 ， 提 示 “ 留 言 添加 成 功 ”。 
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2.10 “在线 订购 模块 设计 


在 线 订购 模块 的 功能 是 实现 在 线 购 买 企业 推出 的 软件 产品 ， 其 操作 的 流程 主要 通过 购物 车 和 订单 
管理 来 实现 。 


2.10.1 在线 订购 模块 概述 


在 线 订购 的 功能 对 所 有 访问 网 站 的 人 开放 ， 没 有 任何 的 权限 限制 。 其 操作 流程 如 图 2.32 所 示 。 


更 新 购物 车 


图 2.32 在 线 订 购 模 块 的 操作 流程 


2.10.2 在 线 订购 模块 技术 分 析 


在 线 订 购 管理 模块 中 ， 不 可 缺少 的 一 项 内 容 就 是 对 订单 进行 打印 。 下 面 就 来 讲解 一 下 订单 打印 功 
能 的 实现 方法 。 在 线 订 购 管理 模块 中 运用 的 是 WebBrowser 打印 方法 。WebBrowser 是 IE 内 置 的 浏览 器 
控件 ， 无 须 用 户 下 载 。 其 优点 是 客户 端 独立 完成 打印 目标 文档 的 生成 ， 减 轻 服务 器 负荷 ， 缺 点 是 源 文 
档 的 分 析 操 作 复杂 ， 并 且 要 对 源 文档 中 要 打印 的 内 容 进行 约束 。 

下 面 介 绍 WebBrowser 控件 的 具体 参数 ， 如 表 2.4 所 示 。 


表 2.4 WebBrowser 控件 的 具体 参数 说 明 


参数 名 称 说 了 明 
document.all. WebBrowser.Execwb(7,1): 表示 打印 预览 
document.all. WebBrowser.Execwb(6.1): 表示 打印 
document.all. WebBrowser.Execwb(6,6): 表示 直接 打印 
document.all. WebBrowser.Execwb(8,1): 表示 页 面 设置 
document.all. WebBrowser.Execwb(]1,1): 打开 页 面 
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续 表 

参数 名 称 说 有明 
document.all. WebBrowser.Execwb(2,1): 关闭 所 有 打开 的 下 窗口 
document.all. WebBrowser.Execwb(4,1): 保存 网 页 
document.all. WebBrowser.Execwb(10,1): 查看 页 面 属性 
document.all.WebBrowser.Execwb(17,1): 全 选 
document.all.WebBrowser.Execwb(22,1): 刷新 
document.all. WebBrowser.Execwb(45,1): 关闭 窗 体 无 提示 


该 技术 的 实现 原理 是 : 首先 通过 onClick 事件 调用 一 个 JavaScript 脚本 ,然后 执行 openprintwindow() 
函数 ， 将 指定 的 变量 值 传递 到 订单 打印 页 中 (printwindow.php〉， 最 后 在 订单 打印 页 中 实现 打印 及 打 
印 预览 的 功能 。 调 用 JavaScript 脚本 和 执行 openprintwindow0 函 数 在 shopping_dd.php 页 中 完成 。 其 关 
键 代码 如 下 : 

例 程 09 ”代码 位 置 ， 光盘 \TM\02\bcty365\shopping_dd.php 


<script language="javascript"> 
function openprintwindow(X,y,z){ // 定 义 一 个 函数 ， 获 取 传 递 的 参数 
/通过 window 对 象 中 的 open 方 法 打开 一 个 新 窗口 ， 并 设置 其 属性 
© window.open("printwindow.php?ddno="+x+"&pv="+z,"newframe","top=200,left=200,width=635, 
height="+(230+20*y)+",menubar=no,location=no,toolbar=no,scrollbars=no,status=no"); 
} 


</script> 
<!-- --------- 通 过 onclick 事 件 调 用 JavaScript 脚 本 ， 传 递 参数 值 。 当 参数 z 的 值 为 "p" 时 执行 打印 功能 ----------- -> 
<td width="75"> <img src="images/bg 14(11).jpg" width="69" height="20" 
四 onclick="javascript:openprintwindow('<?php echo base64 decode($ GET["ddno"]):2>'"<?php echo $gnum;?>",p')" 


style="cursor:hand"/></td> 
<!-- -通过 onclick 事 件 调用 JavaScript 脚 本 ， 传 递 参数 值 。 当 参数 z 的 值 为"v" 时 执行 打印 预览 功能 --…----- -> 
<td width="90"><img src="images/bg 14(12).jpg" width="69" height="20" 
onclick="javascript:openprintwindow('<?php echo base64 decode($ GET["ddno"]);?>'"<2php echo $gnum;?>",'v')" 
style="cursor:hand"/></td> 


Ah 代码 贴 二 

@ open(): 打开 一 个 窗口 ， 可 以 设置 其 URL、 名 称 、 大 小 、 按 钮 以 及 其 他 属性 。 该 方法 的 基本 语法 结构 为 : 

window.open(url,name,features,replace) 

url 是 要 在 新 窗口 中 打开 的 文档 的 URL 地 址 ; name 是 要 打开 的 窗口 的 名 字 ， 用 HTML 链接 的 target 属性 进行 定位 
时 会 有 用 ; features 是 一 个 用 过 号 分 隔 的 字符 囊 , 列举 窗口 的 特征 ; replace 是 一 个 可 选 的 Boolean 值 , 指出 是 否 允 许 URL 
替换 窗口 的 内 容 。 

@ onclick(): 表明 某 元 素 被 筷 标 单 击 触发 的 事件 。 

订单 的 打印 和 打印 预览 的 功能 在 printwindow.php 页 中 完成 ， 首 先 编写 一 个 实现 打印 预览 功能 的 
JavaScript 脚本 ， 然 后 建立 HTML 的 object 标签 ， 调用 WebBrowser 控件 ， 最 后 获取 变量 传递 的 值 ， 当 
变量 的 值 为 p 时 执行 打印 功能 ， 当 变量 的 值 为 v 时 执行 打印 预览 的 功能 。printwindow.php 页 的 关键 代 


码 如 下 : 
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例 程 10 ”代码 位 置 ， 光盘 \TM\02\bcty365\printwindow.php 


<script> 
function printviewO{ // 定 义 一 个 函数 
document.all.WebBrowserl.ExecWB(7,1) ; /| 执行 WebBrowser 控 件 ， 实现 打印 预览 
window.close(); /关闭 窗口 
} 
</script> 
< 建立 HTML 的 object 标 签 ， 调 用 WebBrowser 控 件 ------------------------ -- > 


<object ID="WebBrowserl' WIDTH=0 HEIGHT=0 


CLASSID='CLSID:8856F961-340A-11D0-A96B-00C04FD705A2'></object> 


生生 全 二 在 body 中 调用 onload 事 件 ， 执 行 打印 操作 -一 E> 
<body topmargin="0" leftmargin="0" bottommargin="0" onLoad=" 
<?php 
if($_GETI["pv"]=="p"){ // 判 断 当 变量 值 为 "p" 时 ， 执 行 打印 操作 
ye 
window.print(); 
<?php 
jelseif$_ GET["py"] 一 "v"){ /判断 当 变量 值 为 "v" 时 ， 执 行 打印 预览 操作 
> 
printview() 
<?php} ?> 
心 


Ah 代码 贴 十 


@ document.all.WebBrowserl.ExecWB(7,1): WebBrowser 控件 中 的 参数 ， 表 示 打 印 预览 。 
@ onLoad: 表明 某 对 象 已 载 入 窗口 。 

@ print(): window 对 象 中 的 一 个 方法 ， 实 现 打印 的 功能 。 

订单 打印 操作 的 运行 结果 如 图 2.33 所 示 。 


2 169. 1. 50/T=efs /haty305 /sr aN 生生 


可 到 邮编 : 130025 


国 宇 电 话 : 0431-12345878 
医 常规 | 进项 | 
ml < 元) 光量 4 元? 
可 款 j 打 印 机 boo.o0 1 
SO Stylas 065 Series 在 明日 公共 娘 件 夫 上 元 
你 天 要 支付 的 全 入 总 计 为 2,120.05 元 
状 者。 从 各 就 寺 首先 项 9 
六 ml 0 更 
坦 拓 打印 机 
os 机 二 TCF 
厂 打 多 们 中 
本 
个 全 者 中 从 数 吕 [| 
大 再 国 四 。 记 当前 页 面 Q 
| 
Se 
输入 页 到 或 页 面 范围 . 加，5-12 ole 
| 


出 取消 “| 有 员 
图 2.33 订单 打印 操作 的 运行 结果 
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2.10.3 ”购物 车 的 实现 过 程 


国 ”购物 车 使 用 的 数据 表 : tb_bccd 
购物 车 的 功能 是 临时 储存 用 户 选 购 的 商品 ， 用 户 可 以 对 购物 车 中 的 商品 进行 添加 、 修 改 、 删 除 和 
更 新 操作 ， 也 可 以 选择 进行 结算 。 其 运行 的 结果 如 图 2.34 所 示 。 


(了) 您 当前 的 位 置 > 购物 车 
商品 名 称 曾 价 (元 ) 数量 (个 ) | 操作 
[| 更 K 旷 量 | 删除 该 项 
六 | 更 改 数量 | 删除 该 项 


继续 购买 ”清空 购物 车 


图 2.34 ”购物 车 的 运行 结果 图 

购物 车 功能 实现 的 第 一 步 是 为 想 要 购买 产品 的 用 户 分 配 一 辆 购物 车 ， 使 其 角 区 记 生 目 己 已 各 过 区 
的 产品 。 其 工作 的 原理 与 超市 中 顾客 使 用 购物 车 进行 购物 是 相同 的 ， 只 是 这 里 使 用 的 不 是 真正 
的 购物 车 ， 而 是 两 个 session 变量 ,一 个 存储 用 户 选 购 商品 的 ID 〈$goodsid) ， 另 一 个 存储 用 户 选 购 该 
商品 的 数量 ($goodsnum〉。 如 果 用 户 在 一 次 购物 中 选 购 多 种 不 同类 的 商品 ， 则 使 用 “@” 对 不 同类 商 
品 的 不 同 ID 和 数量 进行 分 割 。 例 如 ， 用 户 选 购 的 不 同类 商品 id 为 1、2、3， 则 session 变量 $goodsid 
中 存储 的 值 为 “1@2@3@”; 其 中 同一 种 商品 不 能 购买 两 次 ， 如 果 想 要 购买 多 个 同 种 产品 ， 可 以 在 购 
物 车 中 更 改 购买 商品 的 数量 。 在 本 案例 中 ,购物 车 的 分 配 功能 通过 shopping_cart_first.php 文件 来 完成 ， 
shopping_cart_first.php 文件 的 代码 如 下 : 

例 程 11 ”代码 位 置 : 光盘 \TMNWO2\bcty365S\shopping_cart_firstphp 


@ 2php session_start0; // 初 始 化 session 变 量 
四 session register("goodsid"); // 创 建 一 个 session 变 量 
© session_register("goodsnum"); // 创 建 一 个 session 变 量 
if($_SESSION["goodsid"]=="" && $_SESSION["goodsnum"]==""){ /判断 session 变 量 中 的 值 是 否 为 空 
$_ SESSION["goodsid"]=$_GET["id"]."@"; // 如 果 为 空 则 将 商品 的 ID 赋 给 变量 
$_SESSION["goodsnum"]="1@"; // 将 商品 数量 设置 为 1@ 
jelsef 
@ $array=explode("@".$_SESSION["goodsid"]); // 如 果 不 为 空 ， 则 使 用 @ 分 割 不 同 的 商品 ID 
// 判 断 如 果 获 取 的 人 D 在 session 变 量 中 已 经 存在 ， 则 提示 该 商品 已 经 被 放 入 购物 车 
© iflin_array($ GET["id"],$array){ 
echo "<script>alert(' 该 编程 词典 已 经 被 放 入 购物 车 ! ');history.back();</script>"; 
exit; 
} 
$_SESSION["goodsid"].=$_GET["id"]."@"; // 为 session 变 量 赋 值 
$_SESSION["goodsnum"] ="1@"; /为 session 变 量 赋值 


上 
/将 商品 放 入 购物 车 中 ， 并 跳 转 到 购物 车 页 


So 
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echo "<script>window.location.href='shopping_cart.php';</script>"; 

7> 
Ah 代码 贴 二 

@ Session start0: 初始 化 session 变量 。 

@ session register(): 创建 一 个 session 变量 goodsid， 存 储 商 品 ID。 

上 @ session_register(): 创建 一 个 session 变量 goodsnum， 存 储 购 买 商品 数量 。 

@ explode(): 将 字符 串 依 指定 的 字符 串 或 字符 进行 分 割 .。 返回 由 字符 囊 组 成 的 数组 ,每 个 元 素 都 是 string 的 一 个 子 
事 ， 它 们 被 字符 囊 separator 作为 边界 点 分 隔 出 来 。 如 果 设 置 了 limit 参数 ， 则 返回 的 数组 包含 最 多 limit 个 元 素 ， 而 最 后 
那个 元 素 将 包含 string 的 剩余 部 分 ; 如 果 separator 为 空 字符 囊 (") ，explode() 函 数 将 返回 false; 如 果 separator 所 包含 
的 值 在 string 中 找 不 到 ， 那 么 explode0 函 数 将 返回 包含 string 单个 元 素 的 数组 ; 如 果 参 数 limit 是 负数 ， 则 返回 除了 最 后 
的 -limit 个 元 素 外 的 所 有 元 素 。 

@ in_array (): 在 指定 的 数组 中 搜索 某 个 值 ， 如 果 找 到 则 返回 true， 否 则 返回 false。 


在 实现 购物 车 的 分 配 和 添加 商品 的 功能 后 ， 接 下 来 要 做 的 就 是 查看 购物 车 中 的 商品 ， 即 实现 购物 
车 中 商品 展示 的 功能 。 在 购物 车 的 商品 展示 中 ， 可 以 实现 很 多 的 操作 ， 清 空 购物 车 、 删 除 购买 商品 、 
更 改 购买 商品 数量 、 继 续 购物 和 结算 。 

购物 车 商品 展示 的 功能 主要 通过 shopping_cart.php 文件 来 完成 ， 首 先 从 session 变量 中 读 取 商品 的 
ID 和 数量 ， 然 后 根据 商品 的 ID 循环 输出 购物 车 中 的 商品 ， 最 后 以 商品 ID 为 标识 符 设置 不 同 的 超级 链 
接 ， 执 行 删除 商品 或 者 更 改 购买 商品 数量 等 操作 。 其 代码 如 下 : 

例 程 12 ”代码 位 置 ， 光盘 \TM\02\bcty365\shopping_cart.php 


<table width="720" height="47" border="0" align="center" cellpadding="0" cellspacing="1" bgcolor="#999999"> 


<?php 
Sarray=explode("@",$_SESSION["goodsid"]); // 读 取 session 变 量 中 的 商品 ID， 以 @ 进 行 分 割 
$arraynum=explode("(@",$_SESSION["goodsnum"]); 。“// 读 取 session 变 量 中 的 商品 数量 ， 以 @ 进 行 分 割 
Smarkid=0; // 创 建 变 量 ， 初 始 值 为 0 
for($i=0;$i<count($array);$it+){ // 应 用 for 循 环 语句 循环 输出 商品 ID 的 值 
if($array[$i]!=""){ /判断 如 果 商 品 ID 的 值 不 为 
S$markid++; /增加 变量 Smarkid 的 值 
上 
} 
if($markid==0){ // 判 断 如 果 变 量 $markid 的 值 为 空 则 输出 下 面 的 内 容 
?> 
<tr> 


<td height="22"” colspan="4" bgcolor=-"#FFFFFF"><div align="center"> 对 不 起 您 的 购物 车 中 暂 无 商品 信 
息 !</div></td> 


</tr> 
<?php 
j}elsef // 如 果 $markid 的 值 不 为 空 ， 则 执行 下 面 的 内 容 
Stotalprice=0; // 创 建 变 量 $totalprice， 初 始 值 为 0 
for($i=0;$i<count($array);$i++){ /循环 输出 数组 中 的 商品 ID 值 


if($array[$i]!=""){ 
// 根 据 获取 的 商品 人 D 的 值 ， 从 数据 库 中 获取 对 应 产品 的 信息 
S$sqlcart=mysql query("select * from tb bccd where id=".$array[$i]."",$conn); 
Sinfocart=mysql_fetch_array($sqlcart) 
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<tr> 

<form name="form<?php echo $array[$i]?>" method="post" action="changegoodsnum.php"> 

<td height="22" bgcolor="#FFFFFF">é&nbsp;<?php echo unhtml($infocart["bccdname"]):?></td> 

<td height="22" bgcolor="#FFFFFF"><div align="center"><?php echo 
number format($infocart["price"],2);?></div></td> 

<td height="22" bgcolor="#FFFFFF"><div align="center"><input type="text" name="goodsnum" 
value="<?php echo $arraynum["$i"];?>" class="inputcss" size="8" ><input type="hidden" name="id" value="<?php echo 
$infocart["id"];?>" ></div></td> 

<td height="22" bgcolor="#FFFFFF"><div align="center"><a href="javascript:form<?php echo 
$array[$i]?>.submit();" class="al"> 更 改 数量 </a>&nbsp:|&nbsp;<a hre 仁 "delgoods.php?id=<?php echo $infocart["id"];?>" 
class="a1"> 删 除 该 项 </a></div></td> 

</form> 

</t> 
<?php 
S$totalprice+=S$infocart["price"]*$arraynum["$i"]; 


} 
?> 


<hable> 
2.10.4 商品 订单 的 实现 过 程 


国 商品 订单 使 用 的 数据 表 : tb_bccd、tb dd、tb city 
在 确定 所 要 购买 的 商品 之 后 ， 接 下 来 要 做 的 就 是 进行 购物 结算 ， 填 写 用 户 购物 订单 ， 将 订单 保存 
到 数据 库 中 ， 并 且 随 机 生成 一 个 订单 号 ， 作 为 订单 的 唯一 标识 。 生 成 订单 的 运行 结果 如 图 2.35 所 示 。 
(3) 你 当前 的 位 置 > 订单 处 理 


吉林 省 明日 科技 有 限 公司 -编程 词典 订单 


订单 号 : 07120216774091 
; 潘 晒 
:34 


: 长 春 市 


商品 名 称 单价 (元 ) 数量 小 计 ( 元 ) 


上 
商品 总 计 : 666.00 元 

邮 虽 : 

你 需要 支付 的 金额 总 计 为 : 906.10 元 


40.10 元 


图 2.35 生成 订单 的 运行 结果 图 
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订单 提交 以 后 用 户 可 以 选择 汇款 的 方式 : 一 是 选择 网 上 支付 ， 那 么 将 跳 转 到 企业 指定 的 网 上 银行 
进行 汇款 ， 汇 款 的 操作 将 在 企业 指定 的 网 上 银行 中 进行 ， 这 里 不 做 讲解 ， 二 是 选择 到 指定 的 银行 向 企 
业 提 供 的 账号 中 汇款 。 企 业 将 在 收 到 汇款 后 按照 用 户 指定 的 地 址 和 方式 将 产品 送 到 。 商 品 订单 的 生成 
和 处 理由 shopping_cart_getuserinfo.php 和 savebuyuser.php 文件 来 完成 。 

订单 处 理由 savebuyuser.php 完成 ， 首 先 连接 数据 库 ， 随 机 生成 一 个 订单 号 ， 然 后 获取 购物 车 中 的 
商品 信息 ， 最 后 将 商品 信息 和 订单 号 存储 到 数据 库 中 。 其 代码 如 下 : 

例 程 13 ”代码 位 置 : 光盘 \TM\02\bcty365\savebuyuser.php 


<?php session start(); // 初 始 化 session 变 量 
include_once("conn/conn.php"); // 连 接 数 据 库 
$ddnumber=substr(date("YmdHis"),2,8).mt_rand(100000,999999); // 随 机 生成 订单 号 


$sql=mysql_query("select * from tb_city where id=".$_POST["city"]."",$conn); // 读 取 数 据 库 中 的 城市 信息 
S$info=mysql fetch array($sql); 
if($shfs—"1"){ // 判 断 用户 选 择 的 送 货 方式 
$yprice=$info[pt]; 
$shfs=" 普 通 邮 递 "; 
}elseift $shfs=="2"){ 
$yprice=$info[kd]; 
$shfs=" 邮 政 特快 专递 EMS"; 
} 


S$array=explode("@",$_SESSION["goodsid"]); // 以 @ 来 分 割 session 变 量 中 存储 的 商品 ID 
$arraynum=explode("(@",$_SESSION["goodsnum"]); // 以 @ 来 分 割 session 变 量 中 存储 的 商品 数量 
S$totalprice=0; 
for($i=0;$i<count($array);$i++){ /循环 读 取 数组 中 商品 的 ID 
if($array[$i]!=""){ 
$sqlcart=mysql_query("select * from tb_bccd where id=".$array[$i]."",$conn); 
Sinfocart=mysql fetch array($sqlcart); 
S$totalprice+=S$infocart["price"]*$arraynum["S$i"]; 
} 
} 
S$totalprice=$totalprice+$yprice; /获取 汇款 金额 
/将 表单 中 提交 的 数据 存储 到 数据 库 中 


if(mysql_query("insert into 
tb dd(ddnumber,recuser,sex,address,yb,qq,email,mtel,gtel,shf’s,spe,slc,yprice,totalprice,createtime,cityid) 
values(".$ddnumber.",".$ POSTI"recuser"].",".$ POST["sex"].",".$ POST["address"].",".$ POST["yb"].",".$ POST["qq" 
.$_POST["mtel"].™",".$_POST["gtel"].™,".$shfs.",".$_SESSION["goodsid"].",".$_SESSION["goo 
dsnum"].", "$yprice.™,". S$totalprice.",".date("Y-m-d H:i:s").™",".$_POST["city"].")",$conn)){ 
Session 人 /注销 session 变 量 goodsid 
session_unregister("goodsnum"); // 注 销 session 变 量 goodsnum 
echo "<script>window.location.href='shopping_dd.php?ddno=".base64_encode($ddnumber).";</script>"; 
}else{ 
echo "<script>alert(' 订 单 信息 保存 失败 ， 请 重 试 !");</script>"; 


四 
?> 


2.10.5 ”单元 测试 


在 在 线 订购 模块 的 测试 过 程 中 ， 当 执行 删除 购物 车 中 某 个 商品 的 操作 时 ， 发 现 该 项 操作 没 能 正确 
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执行 ， 指 定 的 商品 没有 被 删除 。 分 析出 错 原因 : 首先 ， 从 该 功能 实现 的 思路 入 手 ， 并 且 仔 细 核 对 其 中 
使 用 的 变量 以 及 函数 是 否 正确 

删除 商品 的 操作 是 根据 商品 的 ID 来 进行 处 理 的 ， 当 单 击 “删除 ”超级 链接 时 ， 将 指定 商品 的 ID 
通过 变量 $ides 传 入 到 执行 删除 商品 操作 的 文件 delgoods.php 中 ， 然 后 在 delgoods.php 文件 中 ， 获 取 变 
量 $ides 传 入 的 ID 值 ， 并 且 根 据 ID 值 完 成 删除 购物 车 中 指定 商品 的 操作 。 在 查看 该 功能 实现 的 过 程 中 
发 现 ， 定 义 的 变量 $ides 与 delgoods.php 文件 中 $_GET["id"] 获 取 的 变量 值 不 一 致 ， 从 而 导致 删除 商品 的 
操作 没有 正确 执行 ， 代 码 的 出 错位 置 如 图 2.36 所 示 。 
shopping_cart. php 文 件 中 执行 删除 操作 的 内 容 


”bgcolor= “#FFFFFF” 


td height=" 
1i 


2nhn echo $array[$1]?>. submit () ;”class="al"> 更 改 数量 </a> 


- > “id"] ;?>”class="al" > 删除 该 项 《/a>》 


le @", $_SESSION[" goodsid"]) ; 

$arraynun=explode ("@", $_SESSION[”goodsnum”]) : 
Skey=array_search($id, $arrayid) ; 

$arrayid[$key]=""; 

$arraynum[$key]="" ; 

$_SESSION[" goodsid”]=implode (“@”, $arrayid) ; 
$_SESSION[" goodsnum” ]=implode ("@”, $arraynum) ; 

echo “scriptwindow. location. href=’ shopping_cart. php’ ;</script>"; 
?> 


图 2.36 代码 中 的 错误 显示 


查找 出 错误 原因 ， 将 定义 的 变量 与 获取 的 变量 值 统一 使 用 id， 保 存 文件 ， 重 新 运行 程序 ， 删 除 操 
作 可 以 正常 运行 。 


2.11 社区 论坛 模块 设计 


社区 论坛 模块 为 网 站 的 浏览 者 提供 一 个 交流 的 平台 ， 以 此 来 扩大 网 站 的 影响 力 ， 汇 聚 更 多 的 人 气 ， 
宣传 企业 形象 ， 推 广 企业 产品 。 


2.11.1 社区 论坛 模块 概述 


社区 论坛 模块 为 浏览 者 、 会 员 、 客 户 和 企业 之 间 提 供 一 个 大 的 交流 平台 ， 根 据 身份 的 不 同 ， 给 予 
分 别 拥有 不 同 的 操作 权限 ， 社 区 论坛 模块 的 操作 流程 如 图 2.37 所 示 。 


Sa. 
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浏览 者 


村 


图 2.37 社区 论坛 流程 图 
在 本 论坛 中 ， 浏 览 者 只 能 够 查看 帖子 ; 注册 会 员 既 可 以 查看 帖子 ， 也 可 以 发 布 和 回复 帖子 ;管理 
员 则 具有 发 布 、 回 复 、 查 看 和 删除 的 权限 。 


2.11.2 ”社区 论坛 模块 技术 分 析 


在 社区 论坛 模块 的 实现 过 程 中 , 通过 JavaScript 脚本 和 下 拉 列 表 框 的 结合 实现 一 个 不 同 版 块 之 间 快 
速 跳 转 的 功能 ， 从 而 能 够 更 加 灵活 、 方 便 地 实现 不 同 版 块 之 间 的 跳 转 。 

下 面 分 析 该 技术 是 如 何 实现 的 ， 该 技术 的 实现 综合 3 个 方面 的 内 容 ， 以 一 个 下 拉 列 表 框 为 主 ， 通 
过 PHP 语句 从 数据 库 中 读 取 数 据 作 为 下 拉 列 表 框 的 值 ， 应 用 onchange 事件 来 调用 JavaScript 脚本 ， 实 
现 不 同 版 块 之 间 的 跳 转 。 这 里 以 bbs_top.php 文件 中 的 快速 跳 转 功能 为 例 进行 分 析 。 其 关键 代码 如 下 : 

例 程 14 ”代码 位 置 : 光盘 \TM\02\bcty365\bbs_top.php 


<!-- 创 建 一 个 下 拉 列 表 框 ， 指 定名 称 为 select_type， 并 且 设 置 其 属性 ， 通 过 onchange 事 件 来 调用 JavaScript 脚 本 文件 ， 
实现 页 面 跳 转 --> 

<select name="select_type" class="inputcss" 
oo onChange="javascript:window.location=this.options[this.selectedIndex].value;" > 


<?php 
// 通 过 PHP 语 句 从 数据 库 中 读 取 数据 ， 使 用 数据 的 ID 作为 下 拉 列 表 框 的 值 ， 使 用 数据 的 标题 title 作 为 下 拉 列表 框 显示 的 内 容 
$sql=mysql_query("select * from tb_type_small order by createtime desc",$conn); 
$info=mysql_fetch_array($sql); 
if($info—""){ 
echo "<option> 暂 无 讨论 区 </option>"; 
}else{ 
echo "<option>- 版 块 快速 跳 转 -</option>"; 
dof // 应 用 do...while 循 环 语句 输出 下 拉 列 表 框 中 的 值 


© echo "<option value="bbs_list.php?id=".Sinfolid]."'>".$infoltitle]."</option>"; 
} 
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while($info=mysql_fetch_array($sqD); // 应 用 do...while 循 环 语句 结束 
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1 


> 
</select> 


< 代码 贴 二 

@ onChange: 某 元 素 失去 焦点 ， 并 且 从 用 户 最 后 一 次 访问 以 来 ， 其 值 已 经 改变 。 

location: 用 于 访问 窗口 的 当前 定位 (URL ) ， 既 可 被 读 取 ， 又 可 被 置换 ， 可 以 通过 其 实现 某 个 页 面 的 定位 或 者 
更 新 。 

@ <option value='… >…</option>: 下 拉 列 表 框 中 输出 的 值 ， 以 及 显示 的 内 容 。 


该 技术 实现 的 运行 结果 如 图 2.38 所 示 ， 它 将 实现 从 硬件 查询 模块 跳 转 到 PHP 模块 。 
9) 当前 位 置 >》 社 区 论坛 


辆 “计算 机 硬 半 告 询 版 块 
状 恋 | 心情 主 最 


生日 我 的 计算 机 不 能 启动 了 ? 


ix 
示 软件 工程 /管理 | Software engineering/nanagenent 
rh | 是 世 界 上 便 用 最 广泛 计算机 语言 5 的 谓 和 对 划 的 扩展 称 为 ct+ 
windows 2003 
asp/ asp. net 


图 2.38 版 块 跳 转 功 能 的 运行 结果 


2.11.3 ”论坛 分 类 的 实现 过 程 


国 ”论坛 分 类 使 用 的 数据 表 : tb_bbs、tb_type_big、tb_type_small 
论坛 分 类 可 以 分 为 两 类 ， 一 个 是 论坛 中 大 的 版 块 分 区 ， 分 为 6 个 版 块 : 综合 信息 讨论 区 、 操 作 系 
统 、 程 序 设 计 交 流 区 、 网 管 技术 应 用 、Web 程序 开发 和 数据 库 技 术 ， 其 数据 存储 于 tb_type_big 数据 表 
中 。 另 一 个 是 对 应 不 同 的 版 块 中 不 同 语言 和 技术 的 分 类 , 分 为 11 种 , 其 数据 存储 于 tb_type_small 表 中 。 
论坛 分 类 的 运行 结果 如 图 2.39 所 示 。 
上 Yeb 程 序 开发 


Yeb 程 序 开发 发 帖 数 。 | 热门 帖 数 
计算 机 硬件 咨 淘 


创 陵 时 间 : 2008-12-03 00:00:00 


操作 系统 发 帖 数 。 | 热门 帖 数 


ap/acp_ not 
创建 时 间 : 2000-12-16 00:00:00 
hp 
外 了 时 间 : 2009-12-05 00:00:00 
也 符合 信息 讨论 区 
适合 信息 讨论 区 加 发 帖 数 。 | 热门 帖 委 
5 是 世界 上 使 用 最 广泛 计算 机 语言 。C 的 面向 对 铺 的 扩展 称 为 C++ 


自 娃 时 间 : 2005-12-08 00:00:00 


软件 工程 /管理 | Seftware engineering/eanagesent 


创 纵 时 间 : 2006-12-05 00:00:00 


图 2.39 论坛 分 类 的 运行 结果 
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论坛 分 类 的 实现 原理 很 简单 ， 首 先 从 tb_type_big 表 中 读 取 6 个 版 块 中 的 数据 ， 进 行 循环 输出 ， 然 
后 在 版 块 中 嵌 套 循环 ， 用 于 输出 不 用 语言 的 分 类 数据 。 该 功能 主要 通过 bbs_index.php 文件 来 完成 ， 
bbs_index.php 文件 的 程序 代码 如 下 : 

例 程 15 ”代码 位 置 ， 光盘 \TM\02\bcty365\bbs_index.php 


<?php include_once("top.php"); // 调 用 网 站 头 文件 
include_once("bbs_top.php"); /调用 社区 论坛 的 头 文件 

7> 

<?php 


/循环 输出 数据 表 tb_type_big 中 的 6 个 版 块 数据 

$sql=mysql query("select * from tb type big order by createtime desc",$conn); 

S$info=mysql fetch array($sql); 

if($info—false){ // 如 果 返 回 值 为 false， 则 执行 下 面 的 内 容 


?> 
… 省 略 了 部 分 代码 
<2php 
jelsef /如 果 返 回 值 为 tue， 则 执行 4o…while 循 环 语句 
上 # 外 部 嵌 套 循环 ， 输 出 论坛 中 的 版 块 分 类 数据 */ 
© dof 
2> 
… 省 略 了 部 分 代码 
<table width="750" border="0" align="center" cellpadding="0" cellspacing="1" bordercolor="#FFFFFF" 
bgcolor="#6EBEC7"> 
<?php 
/循环 输出 tb_type_small 表 中 的 不 同 语言 和 技术 的 分 类 数据 
$sqll=mysql query("select * from tb type small where bigtypeid=".S$info["id"]."",$conn); 
S$infol=mysql fetch array($sqll); 
if($infol=—false){ // 判 断 如 果 返 回 值 为 false， 则 执行 下 面 的 内 容 


> 
… 省 略 了 部 分 代码 
<?php 
jelse{ /如 果 返 回 值 为 tue， 则 执行 下 面 的 内 容 ， 输 出 该 版 块 中 对 应 语言 和 技术 的 帖子 详细 信息 


> 
… 省 略 了 部 分 代码 
@ <?php ” 族 内 部 嵌 套 循环 ， 输 出 不 同 语言 和 技术 的 分 类 */ 
dof > 
<tr> 
<td height="30"><font color="#666666"> 创 建 时 间 : <?php echo S$infol["createtime"];?></font></td> 

</t> 

… 省 略 了 部 分 代码 

<2php 

}while(Sinfo1=mysql_fetch_array(SsqlD)); 
上 # 内 部 嵌 套 循环 结束 */ 


2> 


</table> 
<2php 
}while(Sinfo=mysql_fetch_array($sqD)); 


.Gg 
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上 # 外 部 霸 套 循环 结束 ， 对 版 块 中 的 大 类 进行 输出 */ 


x 
<?php include_once("bottom.php"); > 


< 代码 贴 十 
@ do...while 循环 语句 ， 对 论坛 中 大 的 版 块 分 类 进行 循环 输出 。 
@ do...while 循环 语句 ， 对 论坛 中 一 个 版 块 中 的 不 同 语言 和 技术 进行 循环 输出 。 


全 注意 : 在 应 用 do…while 循环 语句 时 ，while 后 的 分 号 不 能 省 略 。 
2.11.4 ”论坛 帖子 浏览 的 实现 过 程 


国 ”论坛 帖子 浏览 使 用 的 数据 表 : tb_bbs、tb_user、tb_reply 

论坛 帖子 浏览 主要 输出 指定 帖子 的 详细 信息 ， 包 括 发 帖 人 、 用 户 级 别 和 注册 的 时 间 ， 以 及 帖子 的 
主题 、 内 容 和 发 帖 时 间 ， 包 括 上 传 的 图 片 。 本 模块 中 是 用 户 权限 使 用 体现 的 最 明显 的 地 方 ， 可 以 分 为 
三 种 情况 : 第 一 以 浏览 者 进行 登录 ， 只 能 是 浏览 帖子 的 内 容 ， 没 有 其 他 权限 ， 第 二 以 会 员 进行 登录 ， 
可 以 对 帖子 进行 回复 ， 发 表 自己 的 看 法 ; 第 三 以 管理 的 身份 进行 登录 ， 不 但 可 以 回复 帖子 ， 而 且 可 以 
对 任何 人 发 布 和 回复 的 帖子 进行 删除 和 顶 帖 的 操作 。 下 面 就 来 看 一 下 以 管理 员 身 份 进行 登录 时 都 具备 
哪些 权限 ， 运 行 结果 如 图 2.40 所 示 。 


饮 如何 配 置 ?iP 环境 


O 2007-12-12 13:19:47 
从 想 请 教 一 下 如 何 配置 PHF 的 环境 


发 贴 人 : lx 
信箱 鲍 0ica 易 Tf 地 址 
用 户 绿 别 : 管理 员 


发 6 站 :5 


注册 时 间 : 2007-12-01 13:15:25 


级 OO :rz 13:21:08 TE 


发 贴 人 : lx 回复 主题 : PIF 的 环境 配置 方法 
信箱 七 0ica 昂 下 地 址 


用 户 级 别 : 管理 员 
发 贴 总 数 : 5 详细 内 容 请 参考 PP 数据 库 系 统 开发 完全 手册 中 的 第 ! 章 


注册 时 间 : 2007-12-01 13;15:25 
图 2.40 管理 员 浏 览 帖子 的 结果 图 
论坛 帖子 浏览 的 功能 通过 bbs_looks.php 文件 完成 ， 首 先 根据 传递 的 ID 值 读 取 指定 的 帖子 数据 ， 
然后 判断 登录 用 户 的 类 型 ， 最 后 根据 用 户 不 同 的 类 型 执行 不 同 的 操作 。 其 代码 如 下 : 
例 程 16 ”代码 位 置 ， 光盘 \TM\02\bcty365\bbs_lookbbs.php 
<?php 


SS 
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/根据 $_GET 传 递 的 数据 获取 tb_bbs 中 的 数据 
$sqlb=mysql_query("select * from tb_bbs where id=".$_GET["id"]."",$conn); 
$infob=mysql fetch array($sqlb); 
/根据 $_GET 传 递 的 数据 获取 tb_user 中 的 数据 
$sql4=mysql query("select * from tb user where id="".$infob["userid"]."",$conn); 
$info4=mysql fetch array($sql4); 
> 
> // 省 略 了 部 分 HTML 代 码 
<table width="180" border="0" align="center" cellpadding="0" cellspacing="0"> 
<tr> 
<td height="22"> 用 户 级 别 : 
<2php 
/根据 用 户 信息 表 tb_user 中 字段 usertype 的 值 判 断 该 用 户 的 类 型 
/如 果 值 为 ! 则 是 管理 员 ， 值 为 2 则 是 后 台 管理 员 ， 值 为 0 则 是 普通 会 员 
© if(Sinfo4["usertype"] 二 "1") echo "管理 员 ";else echo "普通 会 员 "; 
?> 
</td> 
</t> 
</table> 
区 /省 略 了 部 分 HTML 代 码 
<table width="500" height="200" border="0" align="center" cellpadding="0" cellspacing="0"> 
<tr> 
<td width="35" height="20"><div align="center"><img src="images/lt 15(11).jpg" width="25" 
height="25"></div></td> 
<td><?php echo $infob["createtime"];?></td> 


</tr> 
<tr> 
<td height="150" colspan="2"> 
四 <?php 
// 判 断 tb_bbs 表 中 的 字段 photo 是 否 为 宅 ， 为 空 则 执行 下 面 的 内 容 
if(Sinfob[photo]!=""){ 
Sphotos=substr(Sinfob[photo],2,70); // 获 取 图 片 在 服务 器 中 的 存储 路 径 
echo (stripslashes(Sinfob["content"])); // 输 出 帖子 的 内 容 
echo "<img sre=\"Sphotos\">"; /根据 获 取 的 图 片 路 径 ， 输 出 服务 器 中 的 图 片 
jelsef /如 果 tb_bbs 表 中 的 图 片 字 段 photo 为 空 ， 则 执行 下 面 的 内 容 
目 echo (stripslashes(Sinfob["content"])); /只 输出 帖子 的 内 容 
} 
?> 
</td> 
</tr> 
</table> 
<table width="530" height="20" border="0" align="center" cellpadding="0" cellspacing="0"> 
<t> 


<td width="239" height="30">&nbsp;</td> 
<td width="291"><img src="images/lt 15(5).jpg" width="72" height="23" style="cursor:hand" onclick=" 
<?php 
/如 果 $_SESSION["unc"] 的 值 为 室 ， 则 不 可 以 进行 顶 帖 子 的 操作 
if($ SESSION["unc"] 一 ""){f 
echo "javascript:alert(' 请 先 登录 本 站 ， 然 后 进行 此 操作 ! ');window.location.href='index.php';"; 


jelsef 
*。113。 乡 


/否则 将 判断 当前 用 户 的 类 型 ， 如 果 是 管理 员 则 可 以 项 帖 
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$sqlu=mysql query("select usertype from tb user where 
Usernc=".$ SESSION[T"unc"]."",$connJ); 
$infou=mysql fetch array($sqlu); 


9 if(Sinfoul["usertype"]=—1){ // 如 果 用 户 的 类 型 为 1， 则 有 项 帖 的 权限 
echo "javascript:window.location.href="settop.php?id=".Sinfob["id"]."""; 
jelsef // 否 则 不 具备 该 权限 
echo "javascript:alert(' 对 不 起 ， 您 不 具备 该 操作 权限 ! );"; 
} 
} 
> 
"/>&nbsp;&nbsp; 
© <?php 


// 判 断 当前 用 户 是 否 具有 删除 帖子 的 权限 
if($_SESSION["une"]!="")! 
/条 件 为 用 户 不 能 为 室 ， 并 且 是 管理 员 ， 才 具备 删除 帖子 的 权限 
S$sqlu=mysql_query("select usertype from tb_user where 
userne="".$_SESSION["une"].""",Sconn); 
Sinfou=mysql fetch array($sqlu); 
if(Sinfou["usertype"]==1){ 
> 
<img src="images/lt_15(10).jpg" onclick="javascript:iftwindow.confirm(' 您 确定 删除 该 帖 吗 ? 
')==true) {window.location.href='bbs_delete.php?id=<?php echo Sinfob["id"]?>";}" style="cursor:hand"/> 


<2php 
} 
} 
?> 
</td> 

</t> 
</table> 
< 代码 贴 十 


@ $info4["usertype"]: 判断 用 户 的 类 型 ， 如 果 值 为 1 是 管理 员 ， 否 则 为 普通 会 员 。 
@ $infob[photo]: 判断 发 布 的 帖子 中 是 否 含有 图 片 ， 如 果 有 则 输出 ， 没 有 则 不 输出 。 
@ stripslashes(): 将 应 用 addcslashes() 函 数 处 理 后 的 字符 事 返 回 原样 。 
@ 判断 登录 用 户 是 否 具有 项 帖 的 权限 。 
加 判断 登录 用 户 是 否 具有 删除 帖子 的 权限 。 
[| 说 明 : 上 面 给 出 的 是 该 文件 的 部 分 代码 ， 主 要 讲解 了 该 功能 的 实现 方法 ， 完 整 的 代码 可 以 参考 本 
书 光盘 中 TM\02\bcty365\bbs_lookbbs.php 文件 。 


2.11.5 ”论坛 帖子 发 布 的 实现 过 程 
国 ”论坛 帖子 发 布 使 用 的 数据 表 : tb_bbs、tb_user 


论坛 帖子 发 布 通过 两 个 文件 来 完成 ， 一 个 是 帖子 发 布 信息 的 提交 页 bbs_pubs.php， 另 一 个 是 对 提 
交 的 数据 进行 处 理 的 retrieve.php 文件 。 该 功能 实现 的 运行 结果 如 图 2.41 所 示 。 


SS 
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| 


帖子 主题 : 
名 如 您 现在 的 心情 如 何 ? 

全 °°@r ro °° ee@ °° rr 
当前 用 户 : lz 闭 CC 雪人 站 区 rr 
信箱 七 0ica 呈 本 地 址 ecoecg@cecgobog 

加 片 : Er | .四 片 丰 和 iaidone 格式 为 so ina 


发 贴 总 数 ; 5 


用 户 级 别 : 管理 
注册 时 间 : 2 


007-12-01 13:15:25 


LEE 


图 2.41 帖子 发 布 模块 的 运行 结果 
在 发 布 信息 的 提交 页 中 ， 显 示 当 前 用 户 的 个 人 信息 ， 设 置 添加 数据 表单 元 素 ， 其 中 表单 元 素 的 设 
计 如 表 2.5 所 示 。 
表 2.5 ”发布 信息 页 中 使 用 的 表单 元 素 


名 称 | 元 素 类 型 重要 属性 含义 
form_bbs, form method="post" action="retrieve.php" enctype="multipart/form-data” 发 帖 表 单 
class="inputcss" style="background-color:#6EBEC7"> 
<2php 
S$sql=mysql_query("select * from tb_type_small order by createtime 
desc", $conn); 
Sinfo=mysql_fetch_array( $sql); 
if($info==false, Ss 
de 区 </option>"; 选择 发 
bbs_type select jelse{ 
四 an 言 或 者 技 
区 术 的 类 别 
<option value="<?php echo $infofid] ;?>"<?php if($_GET[id]=—$info[id]) 
{echo "selected=\"selected\"";}?>><?php echo S$infol[title];?></option> 
<?php 上 
while($info=mysql_fetch_array($sql)); 
}7> 
bbs title text class="inputess" style= background-color#6EBEC7"> 帖子 标题 
bbs head | radio value="<?php echo("images/bbsface/face".($i-1).".gif"):?>" 表情 图 
bbs photo | file id="bbs_photo" class="inputcss" style="background-color:-#6EBEC7" /> 上 传 图 片 
content] textarea id="content1" class="inputcss" style="background-color:#6EBEC7"> 帖子 内 容 
Submit submit value=" 提 交 " 提交 表单 


1g 
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在 retrieve.php 页 中 对 表单 提交 的 数据 进行 处 理 ， 将 数据 存储 到 tb_bbs 表 中 ， 并且 更 新 用 户 信息 表 
tb_user 中 pubtimes 字段 的 值 ， 其 中 还 应 用 了 图 片上 传 技术 ， 将 图 片上 传 到 服务 器 中 指定 的 文件 夹 下 。 
retrieve.php 文件 的 代码 如 下 : 


例 程 17 ”代码 位 置 ， 光盘 \TM\02\bcty365\retrieve.php 


<2php session_start(); // 初 始 化 session 变 量 
Stitle=$_ POST[bbs title]; /获取 帖子 的 标题 
$content=$_POST[content1]; // 获 取 帖 子 的 内 容 


必 判断 提交 的 帖子 主题 和 帖子 内 容 是 否 为 空 */ 
if($title==""){ 
echo "<script>alert(' 请 输入 帖子 主题 !");history.back();</script>"; 
exit; } 
if($content==""){ 
echo "<script>alert(' 请 输入 帖子 内 容 !");history.back();</script>"; 
exit; } 
/| 
include_once("conn/conn.php"); // 连 接 数 据 库 
/根据 $_SESSION["unc"] 的 值 读 取 数 据 库 中 用 户 的 信息 
$sql=mysql query("select * from tb user where usernc='".$ SESSION["unc"]."",$conn); 


$info=mysql_fetch_array($sql); /检索 指定 条 件 的 数据 信息 
$userid=$info[id]; /获取 用 户 id 
$typeid=$_ POST[bbs_type]; /接收 版 块 名 称 
Stitle=$_POST[bbs_title]; // 接 收 帖子 主题 
$content=$_POST[content]1]; /接收 帖子 内 容 
$head=$_POST[bbs_head]; /接收 头像 
$createtime=date("Y-m-j H:i:s"); /获取 系统 当前 时 间 
$lastreplytime=$createtime; /将 当前 时 间 赋 给 变量 
Sreadtimes=0; 
Slink=date("YmjHis"); 
@ if(s_FILESI['bbs_photo']["name"]==true)!{ /上 传 图 片 ， 判 断 文件 是 否 存在 ， 如 果 存 在 则 执行 下 面 的 内 容 
@ $photo_name=strtolower(stristr(S_FILES["bbs_photo"]["name' ")); /获取 图 片 后 缀 名 ， 将 字符 转 成 小 写 
if($photo_name!=".gif" & $photo_name!=".jpg" & $photo_name!=".jpeg" ){ /判断 图 片 的 格式 是 否 符合 要 求 
echo "<script>alert(' 您 上 传 的 图 片 格式 不 正确 !);history.back();</script>"; 
Yelsef 
目 S$paths1=$link.mt_rand(1000000,9999999).Sphoto_name; /创建 图 片 的 名 称 
S$photos="./upfile/".$paths1; // 创 建 图 片 的 存储 路 径 
0 move_uploaded_file($_FILES['bbs_photo']["tmp_name"],Sphotos); ”// 将 图 片 存储 到 指定 的 文件 夹 下 
// 向 数据 库 添加 数据 


if(mysql query("insert into tb bbs(userid,typeid,title,content,createtime,lastreplytime,head,readtimes,top,photo) 
values("".$userid.™,".$typeid.",". $title.",".$content."",". $createtime."",".$lastreplytime.”",".$head.",".$readtimes.",'0','$photos' 
)",Sconn){ 


mysql query("update tb_user set pubtimes=pubtimes+1",$conn); // 更 新 tb_user 中 pubtimes 字 段 的 值 
echo "<script>alert(' 新 帖 发 表 成 功 !");history.back();</script>"; 

}elsef 
echo "<script>alert(' 新 帖 发 表 失 败 !");history.back();</script>"; 

’ 


} 
ee // 和 如 果 没 有 提交 图 片 ， 则 执行 下 面 的 内 容 


Re 
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这 mysql_ query("insert into tb_bbs(userid,typeid,title,contenbcreatetime,lastreplytime,headreadtimes,top) values 

(".$userid.™,".$typeid.",". $title.™,".$content.",".S$createtime.","". $lastreplytime.","".$head.",".$readtimes.™,'0)",$conn)){ 
mysql query("update tb_user set pubtimes=pubtimes+1",$conn); 

echo "<script>alert(' 新 帖 发 表 成 功 !"):history.back();</script>"; 


}else{ 
echo "<script>alert( 新 帖 发 表 失败 !"):history.back0;</script>"; 
} 
} 
> 
< 代码 贴 十 


@S$ FILES['bbs_photo']["name"]: $_FILES[] 全 局 变量 ， 获 取 表 单 提交 文件 的 原始 名 称 。 
@ strtolower(): 将 指定 的 字符 转换 为 小 写字 母 。 


stristr(): 获取 指定 字符 囊 ( A ) 在 另 一 个 字符 囊 (B) 中 首次 出 现 的 位 置 到 (B ) 字符 囊 末 尾 的 所 有 字符 囊 
数 如 果 执 行 成 功 则 返回 剩余 的 字符 囊 ， 和 否则 将 返回 false。 


@ mt_rand(): 生成 一 个 随机 数 ， 用 于 上 传 文件 的 名 称 。 
@ move_uploaded_file(): 将 指定 的 文件 上 传 到 指定 的 文件 夹 下 。 


2.11.6 ”论坛 帖子 回复 的 实现 过 程 


国 ”论坛 帖子 回复 使 用 的 数据 表 : tb_bbs、tb_user、tb_reply 


回复 论坛 中 的 帖子 ， 必 须 是 以 会 员 或 者 管理 员 的 身份 进行 登录 ， 否 则 不 能 进行 帖子 的 回复 操作 ， 
其 运行 结果 如 图 2.42 所 示 。 


也 PIT 编程 词典 , 程序 开发 测试 


OO 2007-11-30 11:12:44 
发 贴 人 : TSoft 
信箱 鸭 oica 号 地 址 
户 顷 中 : 普通 会 员 
ee | 欢迎 大 家 提出 宝 货 意 见 | 


注册 时 间 : 2007-11-18 08:42:43 


9 


回 冬 主 题 :网 王 厨 归 入 天 而 区 


图 片 : FVoraclewebpase nr \bety: 测 虹 本 曙 | (图 片 不 能 超过 zs, 格式 为 gif/ jp 
发 贴 人 : TSoft 
信箱 全 0ica 易 了 地 址 | 论坛 回复 模块 测试 ,程序 测试 中 应 该 注意 的 问题 司 
用 户 级 别 : 普通 会 员 
发 贴 总 数 : 4 
注册 时 间 : 


2007-11-18 08:42:43 


回 
有 到 | 本 | 
图 2.42 论坛 帖子 回复 的 运行 结果 
回复 功能 的 实现 主要 通过 bbs_looks.php 和 savereply.php 两 个 文件 。 其 中 应 用 JavaScript 


论坛 帖子 


"117。 
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脚本 对 回复 帖子 的 文本 框 进行 输出 和 隐藏 的 控制 。 在 bbs_looks.php 文件 中 ， 帖 子 回复 使 用 的 表单 元 素 
如 表 2.6 所 示 。 


表 2.6 论坛 帖子 回复 中 的 重要 表单 元 素 


名 称 | 元素 类 型 重要 属性 含义 
form reply | form method="post" action="savereply.php" enctype="multipart/form-data"> | 加 复 表 单 

reply title text class="inputcss" id= "reply title” 可 复 帖 子 主 
bbsid hidden value="<?php echo Sinfob["id"];?>" 对 应 帖子 的 ID 
bbs_head | radio value="<?php echo("images/bbsface/face".($i-1).".gif");?>" | 表情 图 
bbs_photo | file id="bbs_photo" class="inputcss” | 上 传 图 片 


contentl textarea id="content1" 复 帖子 内 容 


Submit submit value=" 提 交 " 


在 帖子 回复 表单 bbs_looks.php 页 中 ， 首 先 判断 登录 用 户 是 否 具 有 回复 的 权限 ， 然 后 根据 提交 的 值 
展开 回复 表单 的 文本 框 ， 在 文本 框 中 输入 回复 的 主题 和 内 容 ， 最 后 将 数据 提交 到 表单 处 理 页 
savereply.php 中 。bbs_looks.php 的 主要 代码 如 下 : 

例 程 18 ”代码 位 置 ， 光盘 \TM\02\bcty365\ bbs_lookbbs.php 


<script language="javascript"> 


// 设 计 回 复 帖子 表格 的 输出 方式 
function show_replyO){ // 定 义 一 个 函数 
ifreply_bbsl.style.display 一 "") // 判 断 当 display 的 值 为 空 时 
{ 
reply_bbsl.style.display="none" ; // 则 输出 表格 
button_show_bbs.value=" 回 复 帖子 "; // 显 示 回 复 帖子 
4 
else ifreply_bbsl.style.display=="none") /判断 当 display 的 值 为 none 时 
1 
reply_bbsl.style.display="" ; // 则 不 输出 表格 
button_show_bbs.value=" 关 闭 窗口 "; // 显 示 关 闭 窗口 
} 
} 
</script> 
-一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 判断 登录 用 户 是 否 具 有 回复 的 权限 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 -- 一 > 
<img src="images/lt_15(9).jpg" width="72" height="23" id="button_show_bbs" style="cursor:hand" onClick=" 


<?php 
if($_SESSION["unc"]—""){ 
echo "javascript:alert(' 请 先 登 录 本 站 ， 然 后 回复 帖子 !);window.location.href="index.php';"; 


jelse{ 
?> 
show_reply() 
<?php } > " 户 


表单 处 理 页 savereply.php 将 表单 提交 的 数据 存储 到 指定 的 数据 库 中 ， 其 实现 的 方法 与 论坛 发 布 中 
的 表单 处 理 技术 是 相同 的 ， 有 关 该 技术 的 详细 讲解 请 参考 2.11.5 节 ， 这 里 不 再 袭 述 。 


Se 
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2.11.7 ”单元 测试 


在 测试 网 上 社区 的 论坛 模块 时 , 发 现 发 帖 和 回帖 时 上 传 的 图 片 不 能 够 正常 显示 。. 运行 结果 如 图 2.43 
所 示 。 分 析 错 误 原因 : 主要 有 两 个 方面 ， 一 是 图 片 没有 上 传 到 指定 的 服务 器 文件 夹 下 ， 二 是 上 传 成 功 
后 ， 没 能 正确 地 读 取 数 据 库 中 指定 图 片 的 路 径 。 

四 当前 位 置 >》 社 区 论坛 论坛 版 块 ”查找 帖子 


发 贴 人 : TSoft 同 | 
= 信箱 仿 0ic4 易 本 地 址 aaa 回 
用 户 级 别 : 普通 会 员 
发 贴 总 数 : 4 
注册 时 间 : 2007-11-18 06:42:43 EEE 


图 2.43 程序 运行 错误 结果 图 
首先 ， 检 测 第 一 种 情况 ， 没 有 出 现 问 题 ， 图 片 可 以 上 传 到 指定 的 文件 夹 下 ， 并 且 图 片 的 路 径 也 可 
以 存储 到 指定 的 数据 表 中 ， 从 而 排除 了 第 一 种 情况 的 可 能 。 
然后 ， 看 第 二 种 情况 ， 查 看 获取 的 图 片 路 径 是 否 正确 。 发 现在 读 取 数据 库 中 图 片 路 径 的 代码 段 中 ， 
使 用 了 错误 的 字段 名 称 ， 数据库 中 图 片 路 径 存 储 使 用 的 字段 名 是 photo， 而 在 程序 代码 段 中 使 用 的 却 是 
photos。 错 误 代 码 如 下 : 


<?php 
if($infob[photo]!=""){ // 判 断 是 否 存 在 图 片 
S$photos=substr($infob[photos],2,70); // 获 取 图 片 存储 的 路 径 
echo (stripslashes($infob["content"])); /1/ 输 出 图 片 的 内 容 
echo "<img src=\"$photos\">"; // 输 出 图 片 
}else{ 
echo (stripslashes($infob["content"])); /1/ 输 出 帖子 内 容 
上 
> 


将 代码 段 中 的 字段 名 进行 修改 ， 然 后 重新 运行 程序 ， 图 片 正常 显示 。 
2.12 后台 首 页 设计 


作为 一 个 完整 的 网 上 社区 系统 ， 要 想 能 够 及 时 地 对 网 站 进行 管理 和 维护 ， 必 须 具有 一 个 强大 的 后 
台 管 理 系统 ， 对 网 上 社区 系统 中 数据 进行 更 新 和 维护 。 
“119 。 g 
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2.12.1 后 台 首 页 概述 


网 上 社区 系统 的 后 台 管 理 采用 的 是 一 种 简单 的 框架 结构 ， 通 过 switch 语句 来 实现 。 其 具体 内 容 


区 
误 


因 办 办 办 多 罗 * 


软件 试用 管理 : 包括 软件 适用 产品 的 添加 和 删除 。 
编程 词典 管理 : 包括 编程 词典 版 本 的 添加 、 删 除 和 编程 词典 内 容 的 添加 和 删除 。 
在 线 订购 管理 : 主要 用 于 管理 用 户 提交 的 订单 。 
软件 升级 管理 : 包括 升级 包 的 添加 、 删 除 和 序列 号 的 添加 和 删除 。 
站 内 公告 管理 : 主要 用 于 添加 和 删除 站 内 公告 。 
技术 支持 管理 : 主要 用 于 添加 常见 问题 和 删除 常见 问题 ， 以 及 对 客户 反馈 信息 进行 管理 。 
下 面 看 一 下 本 案例 中 提供 的 后 台 首 页 ， 该 页 面 在 本 书 光盘 中 的 路 径 为 \TM\02\bcty365\admin\index.php， 
如 图 2.44 所 示 。 


关闭 系统 重新 登录 


| 


田 编程 词典 管理 


添加 编程 词典 版 本 
编辑 编程 记 风 版 本 版 本 名 称 | 添加 时 间 删除 
be) 开发 版 | 2007-12-06 11:52:34 钱 
eh 标准 版 | 2007-12-08 11:52:30 a 
= 简化 版 | 2007-12-08 11:51:46 Es 
田 软 件 试用 管理 专业 版 | 2007-12-08 11:51:17 多 
田 软件 升级 管理 
田 在 线 订购 管理 
田 站 内 公告 管理 


客户 服务 中 心 热 贱 : 0431-84978981 Copyright 2007 (C5) 吉林 省 明日 科技 有 限 公司 


图 2.44 BCTY365 网 上 社区 系统 后 台 首 页 
2.12.2 后 台 首 页 技术 分 析 


网 上 社区 后 台 首页 的 设计 主要 应 用 switch 语句 和 include 包含 语句 ， 其 实现 的 原理 是 : 应 用 switch 
语句 ， 根 据 超级 链接 中 传递 的 变量 值 进行 判断 ， 根 据 不 同 的 变量 值 应 用 include 调用 不 同 的 子 文件 。 该 


Sa 
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技术 的 实现 流程 如 图 2.45 所 示 。 


客户 服务 中 心 热线 ; 0431-84878561 Copyricht 2007 C) 吉林 省 明日 科技 有 限 公司 
图 2.45 网 上 社区 后 台 首页 设计 流程 


为 能 够 更 好 地 理解 这 个 技术 ， 先 来 了 解 一 下 switch 语句 。 该 语句 的 格式 如 下 : 


Switch( expr ){ llexpr 条 件 为 变量 名 称 

case exprl: //case 后 的 exprl 为 变量 的 值 

statementl; // 冒 号 ":" 后 的 是 符合 该 条 件 时 要 执行 的 部 分 

break ; // 应 用 break 来 跳 离 循环 体 
Case expr2 : 

statement2 ; 
break ; 
default: 
statementN; 
break; 

} 

参数 expr 是 表达 式 的 值 ， 即 switch 语句 的 条 件 变量 的 名 称 ; 参数 exprl 放置 于 case 语句 之 后 ， 是 
要 与 条 件 变量 expr 进行 匹配 的 值 中 的 一 个 ; statement1 是 在 参数 exprl 的 值 与 条 件 变 量 expr 的 值 相 匹 
配 时 执行 的 代码 ; break 语句 实现 终止 语句 的 执行 ， 即 当 语句 在 执行 过 程 中 ， 遇 到 break 就 停止 执行 ， 
跳出 循环 体 ，default 是 case 的 一 个 特例 ， 匹 配 了 任何 其 他 case 都 不 匹配 的 情况 ， 并 且 是 最 后 一 条 case 
语句 。 

通过 switch 和 include 语句 来 实现 后 台 管理 功能 的 设计 是 一 个 很 好 的 方法 ,不 但 实现 过 程 简单 ,， 而 
且 操作 也 非常 灵活 。 其 关键 代码 如 下 : 

例 程 19 ”代码 位 置 ， 光盘 \TM\02\bcty365\ admin\wzdh.php 


<?php 
switch($htgD){ // 根 据 变量 提交 的 不 同 值 
case "添加 编程 词典 版 本 ": // 判 断 与 变量 提交 的 值 是 否 相同 
include("addbb.php"); // 如 果 值 相同 ， 则 调用 指定 的 文件 
break; // 并 且 跳 出 本 次 循环 
case "编辑 编程 词典 版 本 ": 


include("editbd.php"); 


四 


"2. 


PHP 项 目 开发 全 程 实录 


人 // 部 分 代码 省 略 
case ™: // 当 变量 的 值 为 空 时 
include("edittell.php"); // 调 用 该 文件 
break; 
} 
> 


2.12.3 ”后 台 首 页 的 实现 过 程 


国 后 台 首 页 使 用 的 数据 表 : tb_bb 

在 后 台 首 页 的 设计 过 程 中 ， 以 switch 循环 语句 为 基础 ， 架 设 整 个 后 台 管 理 功 能 的 框架 结构 ， 充 分 
发 挥 include 包含 语句 的 作用 ， 调 用 不 同 的 文件 执行 不 同 的 管理 操作 ， 应 用 JavaScript 脚本 来 控制 栏目 
列表 的 输出 和 隐藏 。 

控制 栏目 列表 的 输出 和 隐藏 在 menu.php 文件 中 进行 ， 首 先 定义 一 个 函数 change0) 用 于 控制 表格 的 
输出 和 隐藏 ， 然 后 在 表格 中 应 用 onclick 事件 传递 不 同 的 值 到 自 定义 函数 change()， 最 后 根据 不 同 的 值 
显示 不 同 的 内 容 。 其 关键 代码 如 下 : 

例 程 20 ”代码 位 置 ， 光盘 \TM\02\bcty365\admin\menu.php 


<script language="javascript"> 


// 通 过 脚本 语言 控制 文本 框 的 伸展 和 收缩 


function change(x,y){ // 定 义 一 个 函数 
if(x.style.display=="none"){ 1/ 判断 当 样式 的 值 为 "none" 时 
x.style.display=""; 1/ 判断 当 样 式 的 值 为 "none" 时 ， 输 出 样式 的 值 为 空 
} 
else if(x.style.display—"")!{ /判断 当 样 式 的 值 为 空 时 
x.style.display="none"; // 判 断 当 样式 的 值 为 空 时 ， 输 出 样式 的 值 为 "none" 
y.background="images/bg_16_11.jpg"; /输出 背景 图 片 
村 
} 
</script> 


<table width="175" height="28" border="0" align="center" cellpadding="0" cellspacing="4" 
onclick="change(ltzl,img tz1)" style="cursor:hand"> 
<tr> 
<td background="images/bg_16_11.jpg" id="img tz1" class="a4"><div align="left"><img 
src="images/bg_16_21.jpg">&nbsp; 编 程 词典 管理 </div></td> 
</tr> 
</table> 
<table name="tz1" id="tz1" width="170" height="40" border="0" align="center" cellpadding="0" cellspacing="0" 
<?php 
// 根 据 变量 的 值 选 择 执行 的 内 容 ， 当 变量 的 值 不 为 真 时 ， 隐 藏 该 表格 
if(!($_GET[htg1]==" 添 加 编程 词典 版 本 ”||$_GET[htg1]j==" 编 辑 编程 词典 版 本 ”||$_GET[htgl] 一 "添加 编程 词典 " 
ls$_GET[htel] 一 "编辑 编程 词典 " ){ 
?> 


style="display:none" 
<?php } > 
> 


<t> 


Re 
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<td width="40" height="24" background="images/bg 16 16.jpg">&nbsp:</td> 
<td width="114" background="images/bg_16_16jpg"><div align="left"><a href="default.php?htgl= 添 加 编程 词典 
版 本 "> 添加 编程 词典 版 本 </a></div></td> 
</tr> 
</table> 


[0 说 明 : 这 里 给 出 的 只 是 后 台 首 页 实现 过 程 中 的 主要 代码 ， 详 细 代 码 可 参考 本 书 的 光盘 
TM\02\bcty365\admin\ 文 件 夹 下 的 相关 文件 。 


2.13 ”编程 词典 管理 模块 设计 


本 模块 的 功能 是 对 网 站 中 的 编程 词典 进行 管理 ， 包 括 添加 编程 词典 版 本 、 编 辑 编程 词典 的 版 本 、 
添加 编程 词典 和 编辑 编程 词典 。 


2.13.1 编程 词典 管理 模块 概述 


本 模块 的 主要 功能 是 管理 网 站 中 在 线 出 售 的 编程 词典 软件 ， 实 现 对 编程 词典 软件 及 时 的 更 新 和 维 
护 ， 其 管理 的 内 容 主要 包括 添加 和 编辑 编程 词典 的 版 本 ， 添 加 和 编辑 编程 词典 的 详细 信息 。 在 添加 编 
程 词典 时 ， 包 括 名 称 、 版 权 、 图 片 、 类 别 、 内 容 简介 和 不 同 版 本 的 共同 点 ;编辑 编程 词典 包括 版 本 、 
价格 、 简 介 、 功 能 和 服务 ， 其 中 每 一 个 编程 词典 软件 只 可 以 编辑 一 次 ， 不 可 以 进行 重复 编辑 ， 如 果 要 
重新 编辑 ， 就 必须 将 已 经 编辑 过 的 信息 删除 。 


2.13.2 ”编程 词典 管理 模块 技术 分 析 


在 编程 词典 管理 模块 中 ， 应 用 到 图 片上 传 技术 ， 通 过 该 技术 将 编程 词典 的 界面 效果 上 传 到 服务 器 
的 指定 文件 夹 下 。 该 技术 主要 通过 move_uploaded_file() 函 数 来 实现 ， 其 中 还 应 用 到 is_dir()、mkdir() 函 
数 ， 判 断 指定 的 文件 夹 是 否 存 在 和 创建 文件 来， 还 有 mt_rand()、strstr() 函 数 和 $_FILES[] 全 局 变量 。 为 
了 更 好 地 理解 和 掌握 图 片上 传 处 理 技术 ， 这 里 以 编程 词典 模块 中 的 savebccd.php 文件 为 例 进行 讲解 。 

首先 应 用 is_dir0 函 数 判断 在 服务 器 中 是 否 存 在 指定 的 文件 夹 ， 如果 不 存在 则 应 用 mkdir() 函 数 创建 
一 个 新 的 文件 夹 。 

然后 应 用 $_FILES[] 全 局 变量 获取 图 片 名 ， 应 用 strstr() 函 数 获取 图 片 文件 的 后 级 名 ， 为 避免 出 现 同 
名 文件 覆 羔 ， 这 里 应 用 系统 的 当前 时 间 和 mtrand() 函 数 获取 的 一 个 7 位 随机 数字 作为 图 片 的 名 称 。 
最 后 确定 图 片 在 服务 器 中 存储 的 路 径 ， 将 图 片上 传 到 指定 的 文件 夹 下 。 而 数据 库 中 存储 的 数据 是 
图 片 在 服务 器 中 的 路 径 ， 当 需要 输出 图 片 时 ， 只 需要 获取 到 数据 库 中 图 片 的 路 径 即 可 。savebccd.php 
文件 的 代码 如 下 : 

例 程 21 ”代码 位 置 ， 光盘 \TM\02\bcty365\admin\savebccd.php 


<?php include_once("../conn/conn.php"); // 连 接 数 据 库 
$bccdname=$ POST[bccdname]; // 获 取 POST 方 法 提交 的 值 
S$owner=$_POST[owner]; 


“0. 
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$typeid-$ POST[typeid]; 
$content=$ POST[content]; 
$samepart=$ POST[samepart]; 


S$addtime=date("Y-m-j H:i:s"); // 获 取 当 前 时 间 

@ ifis dir(",/bccdimages")==false){ // 判 断 指定 的 文件 是 否 存在 

@ mkdir("/bccdimages"): // 如 果 不 存在 ， 则 创建 一 个 新 的 文件 夹 
S$link=date("YmjHis"); // 获 取 当 前 时 间 


// 为 表单 中 提交 的 数据 重新 命名 ， 以 当前 时 间 和 随机 数 作为 名 称 
// 其 中 使 用 $_FILES 获 取 表单 中 真实 的 名 称 ， 使 用 strstr 函 数 获 取 文 件 的 后 级 
© $path=$link.mt rand(1000000,9999999).strstr($ FILES["imageaddress"]["name"],"."); 


Saddress="./bccdimages/".$path; // 定 义 文件 上 传 的 路 径 

@ move_uploaded _file($ FILES["imageaddress"]["tmp_name"],$address); /将 文件 上 传 到 指定 的 文件 中 
$imageaddress="./admin/bccdimages/".$Spath; /获取 上 传 文件 在 服务 器 中 的 存储 路 径 
/将 表单 中 提交 的 数据 存储 到 数据 库 中 


$query=mysql query("insert into tb bccd(bccdname,owner'typeid,content,sameparbimageaddress,addtime) 
values('$bccdname',$owner','$typeid','$content','$samepart','Simageaddress','$addtime')",$conn); 
if($query—true)!{ 
echo "<script>alert(' 编 程 词典 添加 成 功 ! "):history.back();</script>"; 
}elsef 
echo "<script>alert(' 编 程 词典 添加 失败 ! "):history.back();</script>"; 
} 
> 


Ah 代码 由 二 
@is dir0: 判断 指定 的 文件 夹 是 否 存在 ， 如 果 存 在 则 返回 true， 和 否则 返回 false。 
@ mkdir(); 创建 一 个 新 的 文件 夹 。 
上 @ mt_rand(): 根 据 提供 的 参数 min 和 max 生成 随机 数 , 如果 没有 提供 可 选 参 数 min 和 max, 则 返回 0 到 RAND_MAX 
之 间 的 伪 随 机 数 。 
strstr(0): 获取 一 个 指定 字符 囊 在 另 一 个 字符 囊 中 首次 出 现 的 位 置 到 后 者 末尾 的 子 字 符 囊 。 如 果 执行 成 功 ， 则 返回 
剩余 字符 囊 ( 存 在 相 匹 配 的 字符 ) ; 如 果 没 有 找到 相 匹配 的 字符 ， 则 返回 false。 
$_FILES[]: 全 局 变量 ， 获 取 所 有 上 传 文件 的 信息 。 该 全 局 变量 还 可 以 获取 到 其 他 的 值 ， 其 中 
$_FILES[imageaddress']['mmame'] 获 取 的 是 客户 端 机 器 文件 的 原名 称 ;， $_FILES[imageaddress'"]['size'] 获 取 已 上 传 文件 的 大 
小 ， 单 位 为 字 节 ; $_FILES[imageaddress'][tmp_name] 获 取 文 件 被 上 传 后 在 服务 端 储存 的 临时 文件 名 ; 
$_FILES[imageaddress']['error'] 获 取 和 该 文件 上 传 相关 的 错误 代码 。 
@ move_uploaded_file(): 应 用 POST 方法 实现 文件 的 上 传 ， 参 数 filename 指定 要 上 传 的 文件 地 址 ; 参数 destination 
指定 文件 上 传 到 服务 器 后 的 存储 目录 及 名 称 。 


全 注意 : 应 用 POST 方法 上 传 图 片 文件 时 ， 应 当 在 上 传 表单 的 <form> 标 记 中 添加 以 下 内 容 
enctype="multipart/form-data"。 


2.13.3 ”添加 编程 词典 的 实现 过 程 


国 ”添加 编程 词典 使 用 的 数据 表 : tb_bccd、tb_type 
添加 编程 词典 的 功能 是 向 数据 库 中 添加 编程 词典 的 详细 信息 ， 包 括 编程 词典 的 名 称 、 版 权 、 图 片 、 
“124。 


类 别 、 内 容 简 介 和 不 同 版 本 的 共同 点 
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其 运行 结果 如 图 2.46 所 示 。 


编程 司 典 名 称 : FIP 编程 词典 | 
版 权 所 有 : 车 条 省 明 惠 科技 有 限 公 司 | 
图 片 路径 : 。 | EDocments ISSUE 
所 属 类 别 : | 『 PHP 类 可 
到 浊 大 生 分 呈 生 天 行 的 避 及 彬 关 的 质 相 为 [天 的 PiE 妥 好 者 提供 一 国 | 
个 
内 容 简介 : 
| 
| J 
[针对 不 同 的 版 本 , 其 中 涉及 到 不 同 难 易 程 度 的 知识 ~ 
不 同 版 本 相同 点 : 
i 


图 2.46 添加 编程 词典 模块 的 运行 结果 


添加 编程 词典 信息 模块 主要 通过 addbccd.php 和 savebccd.php 文件 来 完成 ， 其 中 在 addbccd.php 文 
件 中 主要 是 设计 表单 元 素 ， 而 savebccd.php 文件 主要 是 对 表单 中 提交 的 数据 进行 处 理 。addbccd.php 文 
件 中 使 用 的 表单 元 素 如 表 2.7 所 示 。 


表 2.7 添加 编程 词典 页 中 使 用 的 重要 表单 元 素 


名 称 | 元 素 类 型 重要 属性 含义 
Pe pe ethod = Tpoet “aptione Savebool png onSubmit="return chkinput(this)" 编程 词典 表单 
enctype="multipart/form-data"> 
bccdname text Size="25" class="txt_grey" 编程 词典 名 称 
Owner text " size="25" class="txt_grey” 版 权 所 有 者 
imageaddress file Size="25" class="txt_grey" 界面 图 片 


<2php include_once("../conn/conn.php"); 
S$sql=mysql_query("select * from tb_type order by createtime desc",$conn); 
$info=mysql_fetch_array($sqD; 


_， 这 S$info 一 false){ echo "<option > 暂 无 类 别 </option>"; 选择 编程 词典 
typeid select 
}else{ 的 版 本 
dof 
echo "<option value=".$info[id].">".$info[typename]."</option>"; } 
while($info=mysgl_fetch_array($sql));} ?> 
content textarea rows="10" cols="65" class="textarea"> 内 容 简 介 
不 同 版 本 的 
samepart textarea rows="10" cols="65" class="textarea"> 特点 
Submit submit value=" 添 加 " class="btn_grey" 提交 表单 
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savebccd.php 文件 实现 对 表单 中 提交 的 数据 进行 处 理 ， 首 先 通过 $_POST 获取 表单 中 提交 的 数据 ， 
然后 判断 指定 的 文件 夹 是 否 存 在 ， 最 后 将 数据 存储 到 指定 的 数据 表 中 。 其 关键 代码 如 下 : 
例 程 22 ”代码 位 置 ， 光盘 \TM\02\bcty365\admin\savebccd.php 


<?php include_once("../conn/conn.php"); // 连 接 数 据 库 
S$bccdname=$_POST[bccdname]; /获取 POST 方法 提交 的 值 
$owner=$ POST[owner]; 

$typeid=$ POST[typeid]; 

S$content=$ POST[content]; 

$samepart=$ POST[samepart]; 


$addtime=date("Y-m-j H:i:s"); // 获 取 当 前 时 间 

@ ifis dir("./bccdimages")—false)!{ // 判 断 指定 的 文件 是 否 存 在 

@ mkdir("./bccdimages"): // 如 果 不 存 在 ， 则 创建 一 个 新 的 文件 夹 
} 
Slink=date("YmjHis"); // 获 取 当 前 时 间 


// 为 表单 中 提交 的 数据 重新 命名 ， 以 当前 时 间 和 随机 数 作为 名 称 ， 其 中 使 用 $_FILES 获 取 表 单 中 真实 的 名 称 ， 使 用 
strstr 函 数 获 取 文 件 的 后 级 
@ $path=$link.mt rand(1000000,9999999).strstr($ FILES["imageaddress"]["name"],"."); 


$address="./bccdimages/".$path; // 定 义 文件 上 传 的 路 径 
move_uploaded_file($_FILES["imageaddress"]["tmp_name"],$address); // 将 文件 上 传 到 指定 的 文件 中 
Simageaddress="./admin/bccdimages/".$path; /获取 上 传 文件 在 服务 器 中 的 存储 路 径 

/将 表单 中 提交 的 数据 存储 到 数据 库 中 


$query=mysql query("insert into tb bccd(bccdname,owner'typeid,content,sameparbimageaddress,addtime) 
values('$bccdname','$owner','$typeid','$content','$samepart','$imageaddress','Saddtime’)",$conn); 
这 $query 一 true)f 
echo "<script>alert(' 编 程 词典 添加 成 功 !"):history.back(;</script>"; 
jelsef 
echo "<script>alert(' 编 程 词典 添加 失败 !");history.back(;</script>"; 
} 
> 
Ah 代码 贴 十 
@is dir0: 判断 指定 的 文件 是 否 存在 。 
@ mkdir(): 创建 一 个 新 的 文件 天 。 
@ mt_rand(): 获取 随机 数字 。 
strstr(): 函数 获取 一 个 指定 字符 串 在 另 一 个 字符 事 中 首次 出 现 的 位 置 到 后 者 末尾 的 子 字符 事 。 如 果 执 行 成 功 ， 
则 返回 剩余 字符 串 (存在 相 匹配 的 字符 ) ; 如 果 没 有 找到 相 匹配 的 字符 ， 则 返回 false。 


2.13.4 ”编辑 编程 词典 的 实现 过 程 
国 ”编辑 编程 词典 使 用 的 数据 表 : tb_bccd、tb bb、tb_ bbqb 


在 完成 对 编程 词典 信息 的 添加 后 ， 接 下 来 就 可 以 对 编程 词典 的 版 本 信息 进行 编辑 ， 主 要 添加 版 本 
信息 、 价 格 、 简 介 、 功 能 和 推出 的 服务 。 该 模块 的 运行 结果 如 图 2.47 所 示 。 


Sa 
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EE 
编程 间 奥 名 称 添加 时 间 添加 版 本 信息 | ”删除 
2007-12-13 11:44:58 应 加 钱 
2007-12-02 10:29:42 添加 名 
内 容 简介 功能 服务 到 际 
价格 : Pooo 
古本 全面 一 和 司 
1 区 得 词 册 简 
剧 
网 证 强大 局 
记功 
加 
服务 齐全 司 
i 
加 
EE 


图 2.47 编辑 编程 词典 模块 的 运行 结果 


该 功能 的 实现 同样 通过 两 个 文件 , 一 个 是 提交 表单 的 文件 editbccd.php 和 一 个 是 处 理 表单 提交 数据 
的 文件 sacvbccdbb.php。 提 交 表 单 文件 editbccd.php 中 使 用 的 表单 元 素 如 表 2.8 所 示 。 


名 称 


forml 


元 素 类 型 


form 


表 2.8 编辑 编程 词典 页 中 使 用 的 重要 表单 元 素 
重要 属性 


method="post" action="savebccdbb.php" onSubmit="retum 


含 义 
编辑 编程 词典 表单 


chkinput(this)"> 


bccdname 


text 


class="txt_grey" disabled="disabled" value=" 

<?php 

$sql4=mysql_query("select bccdname from tb_bccd where 
id=".$_GET[bccdid]."",Sconn); 

$info4=mysql_fetch_array($sql4); 

echo unhtml($info4[bccdname]); ?> 


编程 词典 名 称 , 这 里 设置 
了 文本 的 只 读 属性 


bccdid 


hidden 


value="<?php echo $ GET[beedid]:?> 


编程 词典 的 ID 


bbid 


Submit 


select 


submit 


<?php $sql3=mysql_query("select * from tb_bb order by 
createtime desc ",$conn); 
S$info3=mysql_fetch_array($sql3); 
if($info3==false){ echo "<option> 暂 无 版 本 信息 </option>"; 
}else{ 
dof ?> 
<option value="<?php echo $info3[id];?>"><?php echo 
unhtml($info3[bbname]);?></option> 
<?php }while($info3=mysg] fetch array($sqgl3)); } ?> 
btn grey" 


选择 编程 词典 的 版 本 


提交 表单 
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sacvbccdbb.php 文件 对 表单 提交 的 数据 进行 处 理 ， 首 先 获取 表单 中 提交 的 数据 ,然后 判断 指定 的 版 
本 是 否 已 经 被 添加 ， 最 后 将 数据 存储 到 指定 的 数据 表 中 。 其 代码 如 下 : 
例 程 23 ”代码 位 置 ， 光盘 \TM\02\bcty365\admin\savebccdbb.php 


<?php 
$bccdid=$_POST[bccdid]; 1/ 获取 表单 中 提交 的 数据 
$bbid=$_POST[bbid]; /获取 编程 词典 id 
Sprice=$_POST[price]; // 获 取 编 程 词典 单价 
$content=$_POST[content]; // 获 取 编程 词典 内 容 
$gn=$_POST[gn]; 1/ 获取 编程 词典 功能 
Sfw=$_POST[fw]; // 获 取 编 程 词典 服务 
include_once("../conn/conn.php"); // 连 接 数 据 库 文件 
// 判 断 提交 的 编程 词典 是 否 已 经 被 添加 
$sql=mysql query("select id from tb bbqb where bccdid='".$bccdid."".$Sconmn); 
Sinfo=mysql_fetch_array($sql); /检索 指定 编程 词典 的 id 
if($info!=false){ // 如 果 检 索 值 为 值 ， 则 弹出 提示 
echo "<script>alert(' 该 版 编程 词典 已 经 添加 !");history.back0;</script>"; 
exit; } 


/于 冰 率 来 素 率 率 素 束 素 来 冰冰 冰 六 束 束 束 站 素 玉 束 率 率 素 素 率 率 让 率 素 素 率 冰冰 冰冰 素 束 可 来 可 虽 束 冰 束 间 玉 站 冰 率 于 素来 率 可 来 来 裤 来 


$query=mysql query("insert into tb bbqb(bccdid,bbid,price,content,gn,fw) 
values('$bccdid','$bbid','$price'’,'$content','$gn','$fw')", Sconn); // 将 表单 中 提交 的 数据 存储 到 数据 库 中 
/更 新 编程 词典 的 价格 
$querys=mysql query("update tb bccd set bbid='$bbid',price='$price' where id=".$Sbccdid.""); 
if($query=—true and $querys—true){ // 如 果 添加 和 更 新 操作 为 真 ， 则 弹出 提示 
echo "<script>alert(' 版 本 信息 添加 成 功 !");history.back();</script>"; 
jelse{ // 如 果 添 加 和 更 新 操作 为 假 ， 则 弹出 提示 


echo "<script>alert(' 版 本 信息 添加 失败 !"):history.back(;</script>"; 
} 
> 


2.14 ”软件 升级 管理 模块 设计 


2.14.1 软件 升级 管理 模块 概述 


软件 升级 管理 模块 实现 对 软件 升级 包 的 管理 ， 其 具体 的 功能 包括 添加 升级 包 、 编 辑 升级 包 、 添 加 
序列 号 和 编辑 序列 号 。 软 件 升级 管理 模块 中 的 添加 升级 包 和 添加 序列 号 是 一 一 对 应 的 ， 其 中 根据 所 属 
的 类 别 和 版 本 来 确定 升级 包 对 应 的 序列 号 ， 每 一 个 版 本 一 个 类 别 的 升级 包 对 应 一 个 序列 号 。 


2.14.2 ”软件 升级 管理 模块 技术 分 析 


在 软件 升级 包 管 理 模 块 中 ， 应 用 到 一 个 动态 输出 下 拉 列 表 框 中 值 的 技术 。 下 面 就 来 讲解 一 下 该 技 
术 是 如 何 实现 的 ， 在 讲解 该 技术 之 前 ， 先 来 了 解 下 拉 列 表 框 的 基本 结构 : 

<select name="select"><!-->name 指 定 该 下 拉 列 表 框 的 名 称 <!--> 
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<!-->selected 设 置 下 拉 列 表 框 的 默认 值 ,默认 值 为 PHP<!--> 
<option selected="selected">PHP</option> 
<!-->value 指 定 的 "mysql" 是 下 拉 列 表 框 传递 的 值 "MYSQL "为 显示 的 内 容 <!--> 
<option value="mysql">MYSQL</option> 
</select> 


所 谓 动 态 输出 下 拉 列 表 框 中 的 值 就 是 从 数据 库 中 读 取 数据 , 将 获取 到 的 数据 输出 到 下 拉 列 表 框 中 ， 
而 不 是 直接 在 下 拉 列 表 框 中 设置 某 个 固定 的 值 。 这 里 以 软件 升级 管理 模块 addsjb.php 文件 中 的 所 属 类 
别 下 拉 列 表 框 为 例 进行 讲解 ， 其 中 设置 下 拉 列表 框 的 名 称 为 typeid， 默 认 值 为 “请 选择 ”，value 的 值 
是 从 数据 库 中 获取 的 ID 值 ， 显 示 的 内 容 为 从 数据 库 中 获取 的 类 型 名 称 。 动 态 输 出 下 拉 列 表 框 中 值 使 用 
的 关键 代码 如 下 : 

例 程 24 ”代码 位 置 ， 光盘 \TM\02\bcty365\ admin\wzdh.php 

< 设置 下 拉 列 表 框 的 名 称 为 typeid------------------------------------- - > 


<select name="typeid" class="txt_grey"> 
<option value="" selected="selected"> 请 选择 </option> 


和 设置 下 拉 列 表 框 的 名 称 为 typeid---…-…-…-…-…---…… -- > 
<?php 

include_once("../conn/conn.php"); // 连 接 数 据 库 

/从 数据 库 中 读 取 编程 词典 类 型 的 数据 


$sql=mysql_query("select * from tb_type order by createtime desc",$conn); 
Sinfo=mysql_fetch_array($sql); 
if($info=false){ 
echo "<option > 暂 无 类 别 </option>"; 
}else{ 


dof // 应 用 do…while 循 环 语句 输出 类 型 的 ID 和 类 型 的 名 称 
echo "<option value=".$info[id].">".$Sinfo[typename]."</option>"; 
让 
while($info=mysql_fetch_array($sqD); /do…while 循 环 语句 结束 
} 
?> 
</select> 


下 拉 列 表 框 不 但 可 以 动态 输出 数据 库 中 某 个 字段 的 数据 ， 而 且 可 以 输出 数组 中 的 数据 。 下 面 就 实 
现 一 个 在 下 拉 列 表 框 中 动态 输出 数组 中 数据 的 功能 ， 首 先 创建 一 个 下 拉 列 表 框 ， 然 后 设置 下 拉 列 表 框 
的 值 ， 从 数组 中 读 取 数据 ， 应 用 for 循环 语句 进行 输出 。 其 代码 如 下 : 


< 一 设置 下 拉 列 表 框 的 名 称 为 select- 一 一 -一 一 一 一 一 一 一 一 一 一 一 一- 一 -> 

<select name="select" size="1"> 

<?php 
S$string="ASP,PHP,JSP,.NET,DEL,VB,VC"; // 定 义 一 个 字符 串 
$srtings=split(",",$string); // 对 字符 串 进行 分 割 
$count=count(S$srtings); // 获 取 数 组 中 元 素 的 数量 
for($i=0;$i<$count:$i++){ // 根 据 数 组 中 的 元 素 的 数量 进行 循环 输出 

Sresult=$srtings[$i]; // 定 义 变量 ， 获 取 数 组 中 指定 的 元 素 

echo "<option>$result</option>";} // 将 数组 中 的 元 素 输出 到 下 拉 列 表 框 中 

> 

</select> 
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动态 输出 数据 库 中 数据 到 下 拉 列 表 框 的 运行 结果 如 图 2.48 所 示 。 


编程 词典 名 称 : 。 | [PF 编程 启 奥 


版 权 所 有 : 店 林 省 明日 科技 有 限 公司 
图 片 路 径 : [C:\Documents and Settines\| 
所 属 类 别 : 请 选择 辕 | 
ASP 习 
『 JsP 】 类 | 
『 Delphi 上 类 | 
『 Visual Basic 】 类 | 
内 容 乔 介 : 『 Visual Foxpro 】 类 | 


『 Visual C++ | 
『 Power Builder 】 类 


『 .net 上 类 | 
『 PHP 1 类 | 


图 2.48 动态 输出 数据 库 中 数据 到 下 拉 列 表 杠 
2.14.3 ”软件 升级 包 上 传 的 实现 过 程 


国 ”软件 升级 包 上 传 使 用 的 数据 表 : tb_bb、tb_type、tb_sjxz 

软件 升级 包 上 传 在 添加 升级 包 模 块 中 实现 ， 通 过 一 个 文件 域 文本 框 将 升级 报 包 提交 到 服务 器 中 指 
定 的 文件 下 ， 并 且 将 该 文件 在 服务 器 中 的 路 径 存储 到 数据 库 中 ， 便 于 在 前 台 实 现 对 软件 升级 包 的 下 载 。 
其 运行 结果 如 图 2.49 所 示 。 


加 升级 包 

升级 包 名称 : PYF 

所 属 类 别 : [TaeJ 关 司 

版 本 名 称 : 标准 版 图 

下 载 地 址 : Ci\Docunents and Settings\| 人 | 

PIE 物 流 管理 系统 的 升级 包 国 
说 明 及 简介 : 目 
过 | 二 S| 


图 2.49 软件 升级 包 上 传 的 运行 结果 
在 本 模块 中 通过 addsjb.php 文件 来 提交 升级 包 的 信息 , 通过 savesj.php 文件 来 对 表单 提交 的 数据 进 
行 处 理 。 其 中 在 将 升级 包 上 传 到 服务 器 的 指定 文件 夹 的 过 程 中 ， 主 要 应 用 的 是 move_uploaded file0) 函 
数 。 在 savesj.php 文件 中 ， 首 先 获取 表单 提交 的 数据 ， 然 后 判断 服务 器 中 是 否 存 在 指定 的 文件 ， 最 后 应 
用 move_uploaded_file0 函 数 将 升级 包 上 传 到 指定 的 文件 夹 下 ， 并 且 将 数据 存储 到 指定 的 数据 表 中 。 划 
程序 代码 如 下 : 
例 程 25 ”代码 位 置 ， 光盘 \TM\02\bcty365\admin\savesj.php 


<?php 
$name=$_POST[name]; /获取 表单 提交 的 数据 
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S$typeid=$_POST[typeid]; // 获 取 表 单 提交 的 数据 

$content=$_ POST[content]; // 获 取 表 单 提交 的 数据 

Saddtime=date("Y-m-j H:i:s"); // 定 义 时 间 变 量 

S$bbid-$ POST[bbid]; /获取 表单 提交 的 数据 

ifis_dir("./sjxz") 一 包 lse)f // 判 断 指定 的 文件 夹 是 否 存 在 
mkdir("./sjxz"); // 如 果 指 定 的 文件 夹 不 存在 ， 则 创建 一 个 指定 的 文件 夹 

} 

Slink=date("YmjHis"); // 获 取 一 个 时 间 

$path=$link.mt_rand(1000000,9999999).strstr($_FILES["address"]["name"],".");// 重 新 设置 升级 包 名 称 

Saddress="./sjxz/".$path; // 设 置 升级 包 在 服务 器 中 存储 的 指定 路 径 

move_uploaded_file($_FILES["address"]["tmp_name"],Saddress); /将 升级 包 上 传 到 指定 的 路 径 下 

Saddress="./admin/sjxz/".$path; // 获 取 升级 包 在 服务 器 中 的 存储 路 径 

include_once("../conn/conn.php"); // 连 接 数据 库 文件 


/将 上 传 的 数据 存储 到 数据 库 中 ， 这 里 将 升级 包 在 服务 器 中 的 路 径 存 储 到 数据 库 中 
$query=mysql_query("insert into tb_sjxz(name,typeid,content,addtime,address,bbid) 
values('$name','$typeid','$content','$addtime','$address','$bbid')", $conn); 


if($query){ // 如 果 添 加 操作 成 功 ， 则 弹出 提示 
echo "<script>alert(' 升 级 包 添加 成 功 !");history.back();</script>"; 
}else{ // 如 果 添 加 操作 失败 ， 则 弹出 提示 


echo "<script>alert(' 升 级 包 添加 失败 !1");history.back();</script>"; 
} 
> 


2.14.4 软件 升级 包 删 除 的 实现 过 程 


国 ”软件 升级 包 删 除 使 用 的 数据 表 : tb bb、tb_type、tb_sjxz 
软件 升级 包 删 除 的 实现 主要 根据 当前 数据 中 提供 的 ID,， 执 行 delete 删除 语句 ， 将 数据 表 中 相同 ID 
的 数据 删除 。 其 运行 结果 如 图 2.50 所 示 。 


| | 加 如 当前 的 位 置 : 提升 红包 
编程 词典 管理 
技术 支持 管理 编辑 升级 包 
软件 试用 管理 = 升级 包 版 本 | 。 升级 包 关 别 升级 包 名 称 更 新 时 间 山 除 
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该 功能 的 实现 主要 通过 editsjb.php 文件 和 deletesjb.php 文件 ,通过 editsjb.php 文件 输出 数据 库 中 存 
储 的 有 关 升 级 包 的 信息 ， 以 分 页 的 形式 显示 ， 在 每 条 记录 的 最 后 设置 一 个 删除 链接 ， 通 过 脚本 来 调用 
deletesjb.php 文件 ， 根 据 变量 中 的 ID 值 执行 删除 升级 包 的 操作 。 其 关键 代码 如 下 : 

例 程 26 ”代码 位 置 ， 光盘 \TM\02\bcty365\admin\deletesjb.php 


<?php 
$id=$_GET[id]; /获取 变量 传递 的 ID 
include_once("../conn/conn.php" // 连 接 数 据 库 


/执行 删除 操作 ， 将 数据 家中 对 的 ID 的 数据 删除 
if(mysql query("delete from tb sjxz where id=".$id."",$conn)){ 
echo "<script>alert(' 该 升级 包 删 除 成 功 !");history.back();</script>"; /如 果 删 除 操 作成 功 ， 则 弹出 提示 
jelse{ /如 果 删 除 操作 失败 ， 则 弹出 提示 
echo "<script>alert(' 该 升级 包 删 除 失败 !");history.back();</script>"; 


} 
?> 


2.15 在 Linux 系统 下 发 布 网 站 


Linux 下 发 布 基于 PHP 的 网 站 ， 首 先 需 要 配置 PHP 的 运行 环境 ， 其 次 需要 对 网 卡 参 数 进 行 设 定 。 
这 里 将 以 发 布 “BCTY365 网 上 社区 ”网 站 为 例 讲 解 Linux 下 如 何 实现 网 站 的 发 布 。 假 设 已 经 申请 到 表 
2.9 所 示 的 网 络 参 数 。 


表 2.9 申请 到 的 网 络 参数 


参数 值 

IP 192.168.1.* 

Netmask pe 

Network 192.168.1.0 

Broadcast 192.168.1.* 

Gatewa 192.168.1.* 

主机 名 Tsoft 

DNS 168.95.1* 
Linux 下 网 站 发 布 的 操作 步骤 如 下 : 


(1) 配置 PHP 的 运行 环境 ， 在 2.4 节 中 已 经 做 了 详细 介绍 ， 这 里 不 再 袭 述 。 
(2) 将 “BCTY365 网 上 社区 ”网 站 的 所 有 文件 复制 到 Apache 主 目录 下 。 
(3) 设置 主机 名 称 。 在 终端 窗口 中 输入 如 下 命令 编辑 /etc/sysconfig/network 文件 : 
Vi/etc/sysconfig/network 
将 该 文件 中 的 参数 NETWORKING 设置 为 yes， 表 示 启 动 网 络 ， 将 参数 HOSTNAME 设置 Tsoft， 
表示 设置 主机 名 为 Tsoft。 
(4) 设置 网 卡 参数 。 在 终端 窗口 中 输入 如 下 命令 编辑 文件 /etc/sysconfig/network-scripts/ifcfg-eth0: 


sa 32* 
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Vi /etc/sysconfig/network-scripts/ifcfg-ethO 
该 文件 的 相关 参数 设置 如 表 2.10 所 示 。 
表 2.10 设置 网 卡 的 相关 参数 


参数 说 了 明 
DEVICE=eth0 设置 网 卡 名 称 ， 要 与 ifcfg-eth0 对 应 
ONBOOT=yes 指定 在 开机 时 启动 网 卡 
BOOTPROTO=static 设 定 启动 时 获取 人 P 的 方式 
IPADDR=192.168.1.* 设 定 服务 器 人 P 地 址 
NETMASK=255.255.255.* 设 定子 网 掩 码 
BROADCAST=192.168.1.* 设 定 同 网 段 的 广播 地 址 
GETWAY=192.168.1.* 设 定 网 卡 的 网 关 


(5) 设置 DNS 主机 的 IP。 在 终端 编辑 /etc/resolv.conf 文件 : 


vi /etc/resolv.conf 


设置 参数 nameserver 的 值 为 168.95.1.*。 
(6) 重新 启动 网 络 设置 。 在 终端 窗口 中 输入 如 下 命令 : 
/etc/re.d/inin.d/network restart 


ifdow eth0 
ifup eth0 


(7) 打开 浏览 器 ,在 地 址 栏 中 输入 服务 器 IP 地 址 或 域名 ， 打 开 如 图 2.51 所 示 页 面 ， 则 说 明 Linux 


下 “BCTY365 网 上 社区 ”网 站 发 布 成 功 。 


v 
文件) 编 办 (E) 查看 (V) 轩 到 G) 书签 (B) 工具 IJ 窗口 (WD 帮助 ED 


总 - 这 - 吕 、 午 [http//i92.168.1.59/Tsoft/bety385/ J 和 


重新 载 入 
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2.16 ”开发 技巧 与 难点 分 析 


2.16.1 管理 员 权限 的 设置 


为 了 更 好 地 管理 和 维护 网 站 的 论坛 ， 针 对 论坛 设置 了 一 个 管理 员 ， 该 管理 员 不 在 后 台 进 行 操 作 ， 
而 是 在 前 台 为 管理 员 设 置 特殊 的 权限 ， 也 可 以 称 之 为 版 主 。 其 实现 的 原理 是 : 首先 在 数据 库 中 设置 不 
同 的 值 代表 不 同 的 权限 ，“0” 代 表 普 通 会 员 ，“1” 代 表 管 理 员 ; 然后 在 论坛 的 页 面 中 进行 判断 ， 当 
用 户 的 类 型 为 “1” 时 ， 不 但 具有 普通 会 员 的 权限 ， 而 且 具 有 删除 发 布 帖子 、 回 复 帖 子 和 顶 帖 的 权限 ; 
如 果 用 户 的 类 型 不 是 “1”， 则 不 具有 上 述 的 权限 ， 只 能 是 发 布 和 回复 帖子 。 管 理 员 和 普通 会 员 登 录 的 
页 面 效 果 是 不 同 的 ， 如 图 2.52 和 图 2.53 所 示 。 


本 如 何 配置 ?HP 环境 


入 O 2007-12-12 13:19:47 


发 贴 人 : lx 
信箱 惫 oicq 时 I 地 址 
用 户 级 别 : 管理 员 
发 贴 总 数 : 2 
| 注册 时 间 : 2007-12-01 13:15:25 


想 请 教 一 下 如 何 配置 PiF 的 环境 


EEC me 
糙 (OOE 13:21:48 ET 
回复 主题 : PE 的 环境 配置 方法 


发 贴 人 : lx 
信箱 力 0ic4 昂 本 地 址 
用 户 角 别 : 管理 员 
发 贴 总 数 : 2 
注册 时 间 ; 2007-12-01 13:15:25 


详细 内 容 请 参考 PIT 数据 库 系统 开发 完全 手册 中 的 第 ! 章 


图 2.52 管理 员 登 录 的 操作 页 面 
辐 我 的 计算 机 不 能 启动 了 ? 


[> 四 0 or 13:20:4 


ft Internet Exploree 


发 贴 人 : Tsoft 
信箱 国 oica 昂 I 地 址 
用 户 级 别 : 普通 会 员 
发 贴 总 数 : 7 
注册 时 间 : 2007-11-18 06-42-43 


PN 对 不 起 ， 您 不 具备 该 操作 权限 ? 
请 那 为 给 解决 一 下 


图 2.53 ”普通 会 员 登 录 的 操作 页 面 


在 页 面 中 执行 的 判断 语句 判断 登录 用 户 的 类 型 , 然后 根据 类 型 判断 用 户 的 权限 。 其 程序 关键 代码 如 下 : 
<2php 


Sa 
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if($_SESSION["unc"]!=""){ // 判 断 session 变 量 的 值 是 否 为 空 
// 根 据 session 变 量 的 值 获取 该 用 户 的 类 型 
S$sqlu=mysql_query("select usertype from tb_user where usemc=".$_SESSION["unc"]."",$conn); 
S$infou=mysql_fetch_array($sqlu); 


if($infou["usertype"]==1){ // 判 断 当 该 用 户 的 类 型 等 于 "1" 时 执行 下 面 的 内 容 
x 


<!--> 调 用 JavaScript 脚 本 ， 执 行 删除 发 布 帖子 的 操作 <!--> 

<img src="images/lt_15(10)jpg" onclick="javascriptifwindow.confirm(' 您 确定 删除 该 帖 么 ? 
")==true) {window.location.href='bbs_delete.php?id=<?php echo $infob["id"]?>';}" style="cursor:hand"/> 

<?php 


} 
// 如 果 用 户 的 类 型 不 是 "1"， 则 不 执行 上 述 的 内 容 
b 


> 


2.16.2 ”帖子 置顶 的 设置 


所 谓 帖子 置 项 就 是 将 某 个 指定 的 帖子 在 对 应 的 版 块 中 最 前 面 的 位 置 显示 ， 该 权限 只 有 管理 员 才 拥 
有 ， 普 通 会 员 不 具备 该 权限 。 其 实现 的 原理 : 

首先 ， 在 数据 库 中 存储 发 布 帖子 信息 的 数据 表 中 设置 一 个 字段 top， 指 定 该 字段 为 数字 类 型 ， 其 默 
认 值 为 0。 

然后 ， 在 网 页 中 判断 登录 用 户 的 权限 ， 如 果 是 管理 员 则 具有 帖子 置顶 的 权限 ， 否 则 将 弹出 提示 对 
话 框 “对 不 起 ， 您 不 具备 该 操作 权限 ! ”。 

最 后 ， 如 果 是 管理 员 则 执行 settop.php 文件 ， 根 据 对 应 帖子 的 ID 查找 到 发 布 帖子 信息 表 中 对 应 的 
数据 ， 更 新 该 条 数据 中 top 字段 的 值 为 1。 

判断 登录 用 户 权 限 使 用 的 代码 如 下 : 


<?php 
if($_SESSION["une"]—""){ // 判 断 session 变 量 的 值 是 否 为 空 ， 如 果 为 空 则 执行 下 面 的 脚本 
echo "javascript:alert(' 请 先 登录 本 站 ， 然 后 进行 此 操作 !");window.location.href='index.php";"; 
jelsef 


/如 果 不 为 空 则 执行 下 面 的 内 容 ， 判 断 登录 用 户 的 权限 
$sqlu=mysql query("select usertype from tb user where usemc='".$ SESSION["unc"]."",$conmn); 
S$infou=mysql fetch array($sqlu); 


if($infou["usertype"]—1){ /如 果 登 录用 户 的 类 型 是 "1"， 则 说 明 是 管理 员 ， 则 执行 下 面 的 内 容 
echo "javascript:window.location.href='settop.php?id=".$infob["id"].™™"; 
}elsef 


// 如 果 登 录用 户 不 是 管理 员 ， 则 执行 下 面 的 内 容 
echo "javascript:alert(' 对 不 起 ， 您 不 具备 该 操作 权限 !);"; 


上 
> 
实现 帖子 置顶 是 通过 settop.php 文件 来 完成 的 , 在 该 文件 中 , 根据 变量 提交 的 值 获取 到 发 布 帖子 信 
息 表 中 对 应 的 数据 ， 更 新 该 条 数据 中 字段 top 的 值 ， 并 且 对 该 字段 的 值 进行 判断 。 如 果 字 段 top 的 值 为 
1， 则 说 明 该 帖 已 经 置顶 ， 此 时 将 字段 的 值 更 新 为 0， 即 取消 置顶 ， 如 果 字段 top 的 值 为 0， 则 说 明 该 


.5 区 
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帖 没有 进行 置顶 ， 此 时 将 字段 的 值 更 新 为 1， 即 置顶 该 帖 。settop.php 文件 的 程序 代码 如 下 : 


<?php include_once("conn/conn.php"): /连接 数据 库 文件 
/根据 获取 的 ID 值 ， 从 数据 表 中 读 取 到 对 应 的 数据 

$sql=mysql query("select top from tb bbs where id=".$ GET["id"]."",$conn); 

$info=mysql fetch array($sql); 


if($info[top==1){ // 判 断 对 应 数据 记录 中 的 字段 top 的 值 ， 如 果 字 段 top 的 值 为 "1"， 则 执行 下 面 的 内 容 


mysql_query("update tb_bbs set top=0 where id=".$_GET["id"]."",$conn); // 更 新 字段 top 的 值 为 0 
}elseif($info[top]==0){ // 如 果 对 应 数据 记录 中 的 字段 top 的 值 为 "0"， 则 执行 下 面 的 内 容 
mysql_query("update tb_bbs set top=1 where id=".$_GET["id"]."",$conn); // 更 新 字段 top 的 值 为 1 


} 
echo "<script>alert(' 置 上 设置 成 功 !"):history.back();</script>"; 
?> 


2.17 “在线 支付 技术 专题 


所 谓 在 线 支 付 就 是 客户 端 〈 金 融 机 构 需 客户 端 安装 由 金融 机 构 签发 之 数字 证 书 ， 信 用 卡 免 安 装 ) 
将 支付 信息 加 密 后 通过 互联 网 传送 到 支付 网 关 〈 支 付 网 关 是 解决 网 络 上 安全 支付 问题 的 交易 平台 ， 位 
于 互联 网 和 传统 的 金融 机 构 内 部 网 之 间 ， 其 主要 作用 是 将 互联 网 和 金融 网 络 安全 的 连接 起 来 ， 将 不 安 
全 的 网 上 交易 信息 传 给 安全 的 金融 网 络 ， 起 到 隔离 和 保护 金融 网 络 的 作用 ) ， 同 时 金融 机 构 网 上 支付 
系统 反馈 有 关 支 付 信息 ， 客 户 确认 无 误 后 进行 支付 确定 ， 支 付 网 关 负 责 商户 网 上 交易 资金 的 清算 ， 并 
根据 商户 提供 的 开户 行 、 账 号 等 结账 信息 将 网 上 消费 款项 汇总 划 入 商户 账户 。 

BCTY365 网 上 社区 的 在 线 支 付 是 与 中 国 工商 银行 合作 来 共同 完成 的 。BCTY365 网 上 社区 的 在 线 
支付 操作 步骤 如 下 : 

(1) 登录 网 上 社区 ， 如 图 2.54 所 示 。 
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2.54 在 线 订 购 的 操作 页 面 


(2) 购买 商品 。 在 本 页 中 ， 不 但 可 以 购买 商品 ， 还 可 以 查看 商品 的 详细 信息 和 购物 车 中 的 商品 信 
息 ， 如 图 2.55 所 示 。 


Sie. 
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1113111 溃 晤 ， 


1 DE 


所 属 版 本 : ”标准 版 
价格 : 2000.00 元 
版 ” 椒 : 吉林 省 明日 科技 有 限 公司 


图 2.55 购买 商品 操作 页 面 


(3) 进入 购物 车 操作 页 面 。 在 该 页 面 中 ， 可 以 修改 购物 数量 ， 删 除 指定 商品 ， 清 空 购物 车 ， 继 续 


购物 和 统计 购买 商品 的 金额 ， 也 可 以 单 击 “ 结 算 ” 按 钮 进入 到 商品 结算 页 面 ， 如 图 
商品 名 称 单价 (元 ) | 数量 (个 ) 操作 
YP 编程 词典 2,000.00 | 上 ”| 更 改 数量 | 删除 该 项 
《< 继续 购买 清空 购物 车 六 商品 金额 总 计 : 2,000,00 元 EE 


(4) 进入 到 购物 结算 页 面 ， 填 写 收 货 人 的 详细 信息 ， 确 认 后 提交 该 数据 ， 如 图 2.57 所 示 。 


2.56 ”购物 车 操作 页 面 


2.56 所 示 。 


收 货 人 信息 


收 货 人 : 

性 别 ; 

所 在 城市 ; 
详细 联系 地 址 : 
邮政 编码 : 

县 号 码 ; 


了 -mail : 


移动 电话 : 


* 请 务必 正确 填写 您 的 个 人 详细 信息 

[RE 

| 

发 得 司 
FE 
Fa 

[ER 


# 请 务必 正确 填写 悠 的 联系 地 址 和 邮编 ,以 确保 订单 和 货物 顺 利 达 到 4 


13604334wek 固定 电话 : srsssrsss1 


站 请 选择 送 货 方式 


三” 普通 邮递 
他 邮政 特快 专递 ENS 


生成 订单 


2.57 ”填写 收 货 人 的 详细 信息 
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(5) 订单 确认 。 订 单 确认 以 后 ， 就 可 以 提交 订单 ， 准 备 进 行 网 上 支付 ， 如 图 2.58 所 示 。 


吉林 省 明日 科技 有 限 公司 -编程 词典 订单 2007-12-13 11:54:39 
订单 号 : 07121311451945 
收 货 人 : 潘 t* 邮编 : 130000 
移动 电话 : 1360433xrx 固定 电话 : 0431-84978981 
联系 地 址 : 长 春 市 
商品 名 称 单价 (元 ) 数量 小 计 ( 元 】 
1 编程 司 典 2, 000.00 1 2, 000.00 


商品 总 计 : 2,000.00 元 
邮费 : 240.10 元 
你 需要 支付 的 金额 总 计 为 : 2,240.10 元 
图 2.58 订单 确认 
(6) 进行 网 上 支付 。 在 这 里 可 以 选择 工行 网 上 支付 ， 也 可 以 选择 取消 该 订单 ， 如 图 2.59 所 示 。 


”订单 号 : 07121311451945 支付 侈 额 ; 2240.1 元 


站 只 有 在 网 上 支付 成 了 


* 我 们 会 在 48 小 时 内 保留 您 的 订 


| 人 
图 2.59 执行 网 上 支付 

接 下 来 的 操作 在 工行 B2C 支付 页 面 上 进行 。 首 先 网 上 社区 按照 工商 银行 B2C 订单 数据 规范 形成 提 
交 数 据 ， 并 使 用 工商 银行 提供 的 API 和 商户 证 书 对 订单 数据 签名 ， 形 成 form 表单 返回 客户 浏览 器 ， 表 
单 action 地 址 指向 工商 银行 接收 商户 B2C 订单 信息 的 servlet; 然后 在 客户 确认 使 用 工行 网 上 支付 后 ， 
提交 此 表单 到 工商 银行 ， 最 后 工行 网 银 系 统 接收 此 笔 B2C 订单 ， 对 订单 信息 和 商户 信息 进行 检查 ， 通 
过 检查 则 显示 工行 B2C 支付 页 面 。 

客户 通过 工行 B2C 支付 页 面 实现 网 上 支付 ， 商 户 查 询 网 上 银行 的 账户 ， 如 果 货 款 已 经 到 账 ， 则 根 
据 客 户 指定 的 方式 将 货物 送 达 客 户 手中 。 

上 述 内 容 就 是 网 上 社区 系统 的 在 线 支付 流程 ， 涉 及 到 工商 银行 的 操作 内 容 这 里 不 做 讲解 。 这 里 主 
要 讲解 一 下 如 何 将 订单 信息 提交 到 工商 银行 。 该 项 操作 主要 通过 shopping tjdd.php 文件 来 实现 ， 首 先 
从 数据 库 中 读 取 订单 信息 ， 然 后 将 订单 信息 进行 输出 ， 最 后 创建 “取消 订购 ”和 “工行 网 上 支付 ”两 
个 超级 连接 ， 通 过 JavaScript 脚本 来 调用 不 同 的 执行 该 文件 。 其 关键 代码 如 下 : 

<?php ”include_once("conn/conn.php"); include_once("top.php"); /连接 数据 库 和 网 站 的 头 文件 ?> 

<!--> 省 略 了 部 分 代码 <!--> 

<?php 
@ $ddnumber=base64 decode($ GET["ddno"]); // 对 获取 的 订单 编号 进行 base64 解 码 


/获取 该 订单 的 金额 信息 
$sql=mysql_query("select * from tb_dd where ddnumber=".$ddnumber."",$conn); 


Re 
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Sinfo=mysql_fetch_array($sq]); 
$amount=$info["totalprice"]; 


@ $amount=str_replace(",","",number format($amount,2)); // 修 改 数字 的 输出 格式 
$amount=str_replace(".","",number format($amount2)); /修改 数字 的 输出 格式 
> 
加 // 省 略 部 分 HTML 代 码 


<table width="630" border="0" align="center" cellpadding="0" cellspacing="0"> 
<tr><td width="159">&nbsp; 
<2php 
S$sql=mysql query("select totalprice from tb dd where ddnumber=".base64 decode($ GET["ddno"])."",$conn); 
S$info=mysql fetch array($sql); 
echo "<font color=red><strong>" .$info["totalprice"]."&nbsp; 元 </strong></font>"; 
> </td> 
</t> 
</table> 
区 /省 略 部 分 HTML 代 码 
<script language="javascript"> 
/打印 订单 
目 function openprintwindow(x,y,z)f{ 
window.open("printwindow.php?ddno="+x+"&pv="+z,"newframe","top=200,left=200,width=635,height="+( 
230+20*y)+",menubar=no,location=no0,toolbar=no,scrollbars=no,status=n0"); 


} 


</script> 
去 /省 略 部 分 HTML 代 码 
<table width="630" height="25" border="0" align="center" cellpadding="0" cellspacing="0"> 
<tr> 
A 取消 该 订单 二 -一 > 


<td width="75"><img src="images/bg_14(14).jpg" width="69" height="20" style="cursor:hand" 
onclick="javascript:if(window.confirm(' 如 果 取 消 该 订单 ， 则 该 订单 将 被 删除 ， 您 需要 重新 购买 ! 

')==true) {window.location.href='deletedd.php?ddno=<?php echo $ GET["ddno"]:?>";}"/></td> 
1 横行 网 是 尖 付 一 > 
<td width="125"><img src="images/bg_14(15).jpg" width="119" height="20" 

onclick="javascript:window.location.href='ddform.php?orderid=<?php echo 

base64 decode($ GET["ddno"]);?>&amount=<?php echo $amount;?>&orderDate=<?php echo date("Ymdhis");?>';" 

style="cursor:hand"/></td> 


</tr> 
</table> 
< -一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 省 略 了 部 分 代码 -一 -一 -一 一 一 一 一 -一 一 一 一 一 一 - > 
<2php include_once("bottom.php"); // 包 含 网 站 的 尾 文件 > 
Ah 代码 贴 十 


@ base64 decode(): PHP 实现 对 base64 编码 的 字符 进行 解码 。PHP 实现 字符 囊 的 base64 编码 通过 base64 encode() 
函数 。 
@ str_replace(): 实现 字符 串 的 替换 。 该 函数 的 语法 如 下 : 


mixed str_replace ( mixed search, mixed replace, mixed subject , int & count ) 


str_replace() 将 所 有 在 参数 subject 中 出 现 的 search 以 参数 replace 替换 ， 参 数 &count 表示 替换 字符 串 执行 的 次 数 。 
@ openprintwindow (): JavaScript 脚本 中 自 定 义 的 函数 ， 用 于 执行 订单 的 打印 操作 。 
*。139。 g 
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有 关 在 线 支付 流程 中 的 其 他 操作 实现 方式 已 经 在 2.10 节 中 进行 了 详细 的 讲解 ， 这 里 不 再 袭 述 。 则 
具体 的 代码 还 可 以 参考 本 书 的 光盘 TM\02\bcty365\。 


2.18 ”本 章 总 结 


本 章 从 项 目 开 发 的 实际 角度 出 发 ， 以 某 科技 公司 的 实际 需求 为 背景 ， 详 细 的 讲解 “BCTY365 网 上 
社区 ”系统 的 开发 过 程 ， 其 中 以 系统 的 整体 开发 流程 为 主线 ， 重 点 介绍 技术 支持 、 在 线 订购 、 社 区 论 
坛 和 编程 词典 等 儿 个 大 模块 的 实现 方法 ， 并 且 对 管理 员 权 限 设 置 、 帖 子 置顶 设置 和 在 线 支 付 技术 作 技 
巧 和 专题 进行 讲解 ， 而 且 在 本 章 中 还 讲解 在 Linux 下 如 何 搭建 PHP 的 开发 环境 以 及 在 Linux 下 如 何 发 
布 网 站 。 


So. 


第 章 


办 公 自 动 化 管理 系统 


( Apache+PHP+phpMyAdmin+MySQL 5.0 实现 ) 


办 公 室 自动 化 英文 原 称 Office Automation, 缩写 为 OA， 办公 自 动 化 系统 指 实 
现 办 公 室 内 事务 性 业务 的 自动 化 。 

办 公 自 动 化 没有 明确 的 定义 , 最 普遍 的 说 法 是 凡是 在 传统 的 办 公 室 中 采用 各 种 
新 技术 、 新 机 器 、 新 设备 从 事 办 公 上 业务， 都 属于 办 公 自 动 化 的 领域 。 

办 公 自 动 化 系统 与 办 公 自 动 化 在 概念 上 存在 一 定 的 差别 。 办 公 自 动 化 通常 指 办 
公 室 中 配备 具有 自动 化 功能 的 设备 ， 这 些 设备 能 使 基 些 办 公 活 动 自 动 化 或 实现 基 个 
单位 业务 的 自动 化 处 理 ; 而 办 公 自 动 化 系统 则 是 在 办 公 室 自动 化 功能 的 基础 上 发 展 
起 来 ， 以 办 公 自 动 化 技术 为 主体 , 同人 、 组 织 、 制 度 、 环 境 等 相 结 合 的 完整 的 系统 。 
通过 阅读 本 章 ， 读 者 可 以 学 到 : 


MH 办公 自动 化 管理 系统 的 开发 流程 

WI 进一步 学 习 如 何 做 项 目 需求 分 析 与 系统 设计 
WI 页 面 布局 中 的 框架 布局 

H ”使 用 递归 轩 数 做 多 级 下 拉 菜 单 

My 系统 日 志 的 实现 
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3.1 开发 背景 


随 着 中 国 加 入 WTO 及 全 球 经 济 一 体 化 进程 的 加 快 ， 世 界 经 济 已 由 工业 化 经 济 逐 步 进入 网 络 信息 
化 时 代 。 在 信息 时 代 来 临 之 际 ， 各 企业 都 紧 跟 时 代 的 脚步 ， 转 变 着 企业 的 经 营 模式 、 管 理 模式 ， 从 传 
统 的 人 工 管理 体制 ， 向 信息 自动 化 管理 体制 过 渡 。 网 络 自动 化 办 公 系统 就 是 在 这 样 的 大 背景 下 应 运 而 
生 的 。 

信息 时 代 的 到 来 让 人 们 尝 到 了 “信息 爆炸 ”的 滋味 ， 信 息 的 大 量 涌 入 让 企业 在 信息 处 理 方面 应 接 
不 暇 ， 传 统 的 办 公 模 式 、 对 信息 的 处 理 方法 ， 早 已 不 能 满足 企业 对 信息 快速 、 准 确 的 处 理 的 要 求 。 一 
个 企业 对 信息 数据 的 掌握 程度 、 处 理 能 力 ， 体 现 了 一 个 企业 对 市 场 的 敏感 程度 ， 数 据 的 真实 性 、 准 确 
性 直接 决定 着 企业 的 发 展 方向 。 从 传统 的 办 公 模 式 向 自动 化 办 公 管理 模式 转变 ， 提 高 企业 的 信息 处 理 
能 力 ， 以 增强 企业 的 市 场 竞争 力 ， 成 了 企业 发 展 过 程 中 的 首要 问题 。 


3.2 ”需求 分 析 


根据 与 客户 的 多 次 交谈 和 了 解 ， 本 系统 所 面向 的 客户 对 象 情况 如 下 : 

所 属 IT 行业 ， 目 前 主要 以 开发 门户 网 、 企 业 网 等 中 小 型 网 站 为 主 。 

公司 经 过 多 年 经 营 ， 已 经 相对 稳定 ， 并 有 了 自己 的 网 站 、 企 标 、 规 章 制度 和 基本 架构 。 

公司 规模 50~100 人 ， 人 和 手 一 机 ， 主 要 包括 部 门 经 理 、 普 通 职员 、 试 用 人 员 和 实习 人 员 。 

职员 所 用 计算 机 属于 局 域 网 内 网 ， 不 允许 访问 外 网 。 

公司 暂时 分 为 技术 部 、 人 事 部 和 质量 部 ， 但 不 排除 后 期 增加 其 他 部 门 的 可 能 。 

公司 实行 人 性 化 管理 ， 允 许 员 工 自由 发 表意 见 和 想法 ， 还 有 丰富 多 彩 的 活动 ， 如 比赛 、 旅 

游 等 。 

回 ”为 了 提高 工作 效率 ， 所 有 职员 定期 写 工作 计划 ， 包 括 周 计划 、 月 计划 ， 部 门 经 理 还 有 年 计划 
和 任务 计划 。 

回 ”根据 计划 的 完成 程度 和 完成 质量 ， 不 定期 地 选取 优秀 员工 。 


办 办 办 办 多加 


3.3 ”系统 设计 


3.3.1 系统 目标 


本 系统 是 针对 中 小 型 企业 内 部 自动 化 办 公 管理 的 要 求 进行 设计 的 ， 主 要 实现 如 下 目标 : 
回 ”键盘 操作 ， 快 速 响应 。 

回 ”实现 了 文件 类 信息 的 强大 的 管理 能 力 。 

回 ”实现 对 员工 基础 信息 〈 人 事 消息 ) 的 管理 功能 等 。 


Se 


3.3. 
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实现 了 个 人 办 公 的 信息 自动 化 管理 功能 。 

发 布 会 议 信息 ， 并 对 会 议 信 息 进行 管理 。 

对 系统 用 户 进行 管理 。 

为 了 加 强 数据 保密 性 ， 为 每 个 用 户 组 设置 权限 级 别 。 
系统 最 大 限度 地 实现 了 易 安 装 性 、 易 维护 性 和 易 操 作 性 。 
系统 运行 稳定 、 安 全 可 靠 。 


固 加 图 图 因 回 


D 


系统 功能 结构 


根据 系统 分 析 ， 下 面 给 出 系统 的 前 、 后 台 功 能 结构 图 。 
办 公 自 动 化 前 台 功 能 结构 图 如 图 3.1 所 示 。 


企业 绩效 


图 3.1 办 公 自 动 化 前 台 管理 系统 
办 公 自 动 化 后 台 功 能 结构 图 如 图 3.2 所 示 。 
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一 | 系统 日 志 
一 | 数据 备份 


修改 密码 


沪 沼 台北 
注 沼 淄 察 
汉江 天 当 
注 沼 洲 阶 


图 3.2 办 公 自 动 化 后 台 管 理 系统 
3.3.3 系统 功能 预览 


办 公 自 动 化 管理 系统 由 多 个 功能 模块 组 成 ， 下 面 仅 列 出 儿 个 典型 功能 的 页 面 ， 其 他 页 面 参见 光盘 
中 的 源 程序 。 

前 台 登 录 界面 如 图 3.3 所 示 ， 该 页 面 用 于 实现 对 用 户 登 录 的 用 户 名 和 密码 进行 验证 。 企 业 信息 如 
图 3.4 所 示 ， 该 页 面 用 于 显示 企业 文化 和 各 规章 制度 。 


图 3.3 前 台 登 录 (光盘 \TM\03\oa\index.php) 图 3.4 规章 制度 (光盘 \TM\03\oa\qyxx\r_system.php) 


Re 
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个 人 计划 页 面 如 图 3.5 所 示 , 该 页 面 主要 实现 用 户 的 工作 反馈 和 周 、 月 计划 等 功能 。 后 台 登 录 界面 


or 


如 图 3.6 所 示 ， 该 页 面 用 于 管理 员 登 录 后 台 。 


3 工作 反馈 | 
a 0 uh 始 RR 型 
二 2007。 于 下 工作 
3 mo ltl ，， 2 I 
me Fr 下 网 
SA 
TOTEM DUO el 下 2 
OM mt RM Tea 
月 计划 
自生 计划 | I 
一 外 人 习 
3 Rt 本 | 
习 
| 


图 3.5 个 人 计划 (光盘 \TM\WO3\oa\grjh\person_plan.php) 


职员 管 
所 示 ， 该 页 面 用 于 对 功能 使 用 权 的 分 配 。 


办 公 自 动 化 
| | 


ny 
怠 。 亚 者 部 门 
全 需 加 闻 门 
一 一 一 3 2 | 


避 查看 职员 bE D431-12345879 有 芝 下 


夭 统 首页 | 下 新 益 录 | 企业 公告 | 只 助 | 退出 


查找 BI 工 :; [aa 


避 六 加 员 驰 言 0431-12345876 人 于 部 
一 一 一 一 2 珊 汪 vie 


aa [9 ne 2 


品 用 户 姐 座 加 
以 限 分 旧 
一 一 
品系 统 日 不 
数据 备 从 
oa 


理 页 面 如 图 3.7 所 示 ， 该 页 面 主要 用 于 对 职员 的 查询 与 修 


沪 公 自动 化 后 所管 理 孚 绸 


Fad 
Je 用 户 名 [TSoft 审查 。 


maatysonse+comcn 


图 3.6 ”后 台 登 录 (光盘 \TM\WO3\oavadminvindex.php) 
等 功能 。 权 限 分 配 页 面 如 图 3.8 


办 公 局 动 化 


CL 


; 
下 
一 十 


3.7 职员 管理 (光盘 \TMW3\oavadminvzygl\vshow_stafphp) 图 3.8 ”权限 分 配 ( 光 盘 \TM\03\oa\admin\qxgl\pur_assign.php) 


3.3.4 系统 流程 图 


用 户 在 登录 一 个 系统 后 ， 会 ; 


行 一 系列 的 操作 ， 把 这 些 操作 的 过 程 和 结果 以 图 形 的 形式 表现 出 来 ， 


这 就 是 系统 流程 图 。 一 个 好 的 流程 图 ， 不 仅 可 以 让 开发 者 迅速 地 理 清 思 路 、 及 时 解决 出 现 的 问题 ， 也 
可 以 让 使 用 者 很 快 明白 该 系统 的 操作 方式 与 方法 。 下 面 给 出 办 公 自 动 化 管理 系统 的 工作 流程 图 ， 如 


图 3.9 所 示 。 


“5 
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图 3.9 办 公 自 动 化 管理 系统 流程 图 


3.3.5 ”开发 环境 


在 开发 办 公 自 动 化 管理 系统 平台 时 ， 该 项 目 使 用 的 软件 开发 环境 如 下 : 
.服务 器 端 

操作 系统 : Windows 2003 Server。 

服务 器 : Apache 2.0。 

PHP 软件 : PHP 5.0。 

数据 库 : MySQL 5.0。 

MySQL 图 形 化 管理 软件 : PhpMyAdmin-2.5.5。 

开发 工具 : Dreamweaver 8。 

浏览 器 : IE 6.0。 

分 辩 率 : 最 佳 效 果 1024X 768 像素 。 


和 


因 办 因 办 办 办 办 思 


鸭 祝 
柚 
二 
各 


浏览 器 : 推荐 使 用 IE 6.0 及 以 上 版 本 。 


二 
I 
[e272] 
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分 辨 率 : 最 佳 效 果 1024X 768 像素 。 
3.3.6 文件 夹 组 织 结构 
系统 功能 结构 和 系统 流程 设计 完成 后 ， 接 下 来 就 要 设计 网 站 的 文件 夹 结 构 了 ， 合 理 的 文件 夹 结构 


不 仅 易 于 快速 的 开发 ， 对 后 期 系统 的 调试 、 维 护 和 管理 也 能 起 到 事半功倍 的 效果 。 本 系统 的 文件 夹 组 
织 结 构 如 图 3.10 所 示 。 


日 局 一 办 公 自 动 化 率 统 根 目录 
| -DD ahin 后 台 管理 目录 
夯 | bak 数据 备份 
由 ' 回 ne 部 门 管理 模块 
“ 田 国 cm 后 台数 据 库 链接 文件 
问 -~ 后 台 css 靶 本 文件 
“田园 inagss~ 后 台 图片 背 且 目 录 
-四国 in 后 台 公共 链接 文件 
田 辐 js 后 6ijs 肢 本 文件 
xa 权限 管理 模块 
-上田 固 x 一 系统 管理 模块 
， 田 -加 zya 职员 管理 模块 
由 - 回 com 前 台数 据 库 链接 文件 
| 由 -全 css 前 台 css 脚 本 交 件 
| 和牛 gjih 个 人 计划 模块 
| 本 |】 images 前 台 图 片 背 景 目录 
四 加 in 前 台 公共 得 接 文件 
田 国 ji 前 台 ijs 脚 本 文件 
田 辐 kl 和 壮 管 理 酉 
由 :图 jx 企业 绩效 模块 
由 -图 ox 企业 信息 模块 
| 由 -图 rsxx 人 事 消息 模块 
由 - 国 shps 审核 批示 模块 
加 zyta 职员 天 地 模块 


图 3.10 办 公 自动 化 管理 系统 文件 夹 组 织 结构 
3.4 数据 库 设 计 


基于 目前 的 系统 开发 ， 没 有 数据 库 的 支持 根本 是 无 法 想象 的 ， 办 公 自 动 化 管理 系统 更 是 使 用 了 大 
量 的 数据 表 来 存储 数据 。 本 节 就 对 办 公 自 动 化 管理 系统 所 需要 使 用 的 数据 库 进行 说 明 与 设计 。 


3.4.1 数据库 分 析 


由 于 本 系统 采用 的 是 PHP 语言 ， 数 据 库 理所当然 的 使 用 MySQL， 不 仅 是 因为 开发 成 本 低 ， 
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要 的 是 两 者 之 间 的 默契 程度 和 稳定 程度 要 远 远 高 于 其 他 的 数据 库 组 合 。 对 于 一 个 企业 的 内 部 办 公 自 动 
化 管理 系统 是 完全 够 用 了 。 


3.4.2 数据 库 概 念 设计 
根据 以 上 的 需求 分 析 及 系统 分 析 ， 规 划 出 办 公 自 动 化 管理 系统 主要 的 几 个 实体 关系 E-R 图 。 
1. 用 户 信息 实体 


用 户 信息 实体 包括 职员 的 账号 、 密 码 、 姓 名 、 人 性 别 等 表示 个 人 身份 的 数据 资料 ， 如 图 3.11 所 示 。 


图 3.11 用 户 信 息 实 体 E-R 图 
2. 考勤 登记 实体 


考勤 登记 实体 包括 登记 日 期 、 登 记 时 间 、 登 记 类 型 上班 或 下 班 》、 登 记 状 态 (迟到 或 早退 ) 和 
登记 人 等 信息 ， 如 图 3.12 所 示 。 


登记 类 别 


登记 时 间 


考勤 登记 


图 3.12 ”考勤 登记 实体 ER 
3.4.3 数据库 物 理 结构 设计 


在 本 系统 中 创建 了 一 个 数据 库 db_office， 一 共 包 含 13 个 数据 表 ， 如 图 3.13 所 示 。 
Se 
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加 服务 器 : localhost ， 号 数据 库 : db_office 


说 明 
企业 信息 列表 
管理 员 列表 


表 类 型 整理 
th company MylSAM gb2312_chinese_ci 
th_controller MyISAM gb2312_chinese_ci 
th_depart MylSAM gb2312_chinese_ci 
tb_group MyISAM gb2312_chinese_ci 
th_iss MylSAM gb2312_chinese_ci 
th_list MylSAM gb2312_chinese_ci 
th_yb MylSAM gb2312_chinese_ci 
tb_person MylSAM gb2312_chinese_ci 
tb_plan MyISAM gb2312_chinese_ci 
th_register MyISAM gb2312_chinese_ci 
tb_setup MylSAM ”gb2312_chinese_ci 
th_superson MylSAM gb2312_chinese_ci 
th_users MylSAM gh2312_chinese_ci 


1. tb_users (用 户 列 表 ) 
用 户 列 表 主 要 用 于 存储 
该 数据 表 结 构 如 图 3.14 所 示 。 


只 员 


从 由 


部 门 管理 列表 
用 户 组 管理 列表 
审核 列表 
功能 列表 
意见 箱 列表 
人 事 列表 
计划 列表 
登记 列表 

时 间 列表 

忧 秀 员工 列表 
用 户 列表 


图 3.13 db_office 库 中 的 数据 表 列 表 
限于 篇 幅 ， 这 里 只 给 出 主要 的 表 结 构 和 表 说 明 ， 其 他 数据 表 结 构 请 参见 本 书 附带 的 光盘 。 


的 姓名 、 性 别 等 私人 信息 及 部 门 、 工 作 组 等 与 公司 相关 的 公共 信息 。 


加 服务 器 : localhost 加 数据 库 : db_office ， 国 表 


字段 类 型 

id int(4) 
U_user varchar(50) 
Uu_pwd Yarchar(20) 
uname varchar(20) 
U_sex chartl) 
u_birth date 
u_address varchar(50) 
utel varchar(20) 
u_email varchar(50) 
udepart varchar(20) 
is_on int(1) 


2. tb_person (人 事 列表 ) 


:tb_users 

整理 尾 性 Null 默认 额外 说 明 

否 auto_increment ”自动 编号 

gb2312_chinese_ci 否 用 户 账号 
gb2312_chinese_ci 否 用 户 密码 
gb2312_chinese_ci 是 NULL 用 户 姓名 
gb2312_chinese_ci 是 NULL 用 户 性 别 
是 NULL 用 户 生日 

gb2312_chinese_ci 是 NULL 用 户 住址 
gb2312_chinese_ci 是 NULL 用 户 电话 
gb2312_chinese_ci 是 NULL 用 户 Email 
gb2312_chinese_ci 雪 所 尾部 门 
否 激活 账号 

图 3.14 用 户 列表 


人 事 列表 用 于 存储 人 事 部 门 发 布 的 信息 ,如 信息 标题 、 信 息 内 容 、 信 息 时 间 等 。 该 表 结 构 如 图 3.15 


所 示 。 
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加 服务 器 : localhost 剖 数据 库 : db_office ， 国 表 :tb_person 


字段 类 型 屋 性 ”Null 默认 竹 外 说 明 
id int(a) 否 auto_increment ”自动 编号 
p_title varchar(50) gb2312_chinese_ci 否 公告 标题 
p_content mediumtext gb2312_chinese_ci 否 公告 内 容 
p_time date 再 发 布 时 间 
uid int(4) 否 消息 类 别 


3.15 人事 列表 


3.5 ”公共 模块 设计 


本 系统 的 公共 模块 有 conn 数据 库 链 接 文 件 、css 样式 文件 、js 脚本 文件 和 inc 下 的 自 定义 函数 文件 


和 包含 文件 等 儿 类 文件 , 其 中 数据 库 链接 文件 和 css 样式 文件 在 前 面 的 章节 中 有 过 系统 的 介绍 了 , 这 里 
主要 讲解 本 系统 所 涉及 到 的 js 脚本 文件 和 部 分 自 定义 函数 文件 。 


3.5.1 JavaScript 脚本 


在 办 公 自 动 化 管理 系统 中 ，JavaScript 脚本 一 般 用 于 表单 元 素 验证 ， 如 判断 text 文本 框 输入 是 否 为 
空 ， 输 入 格式 是 否 符合 标准 等 。 在 网 页 中 使 用 JavaScript 脚本 的 方式 主要 有 3 种 方式 : 


(1) 


在 网 页 中 使 用 <script></script> 标 签 对 


<script></script> 标 签 对 可 以 放 在 网 页 的 任意 位 置 ， 一 般 是 放 在 <head></head> 或 <body></body> 之 
间 。 代 码 如 下 : 
<head> 


<script>document.write(" 办 公 自 动 化 管理 系统 开发 ");</script> 
</head> 


(2) 
如 果 


在 单独 文件 中 使 用 
JavaScript 脚本 比较 多 ， 而 且 位 置 分 散 不 易 管理 ， 可 以 统一 放 到 一 个 扩展 名 为 js 的 文件 中 ， 


使 该 文件 成 为 JavaScript 脚本 文件 。 在 脚本 文件 中 ,不 需要 使 用 <script></scrip 亿 标签 对 ， 直 接 写 脚本 代 
码 即 可 。 当 有 页 面 需要 使 用 到 里 面 的 JavaScript 脚本 时 ， 可 以 这 样 引用 ， 代 码 如 下 : 


<Script 
(3 


Src="ad_js.js" jangauge="javascript"></script> 


在 表单 元 素 或 标签 中 使 用 
最 直接 的 使 用 方式 ， 如 果 是 少量 的 脚本 则 可 以 这 样 使 用 。 例如， 在 超级 链接 标签 <a> 中 想 要 使 


用 JavaScript 脚本 ,代码 格式 如 下 : 
<a href="#" onclick="alert(hello):">hello</a> 


在 办 公 自 动 化 管理 系统 中 ， 这 3 种 方法 都 有 使 用 到 ， 在 后 面 涉及 到 具体 应 用 的 时 候 再 进行 说 明 。 
下 面 先 来 看 两 个 经 常 使 用 到 的 脚本 函数 。 
S “150。 
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(1) 验证 函数 ， 判 断 表 单元 素 是 否 为 空 。 如 果 为 空 ， 则 返回 色 lse， 并 将 光标 焦点 定位 到 出 问题 的 
表单 元 素 。 程 序 代 码 如 下 : 
例 程 01 ”代码 位 置 ， 光盘 \TM\O3\oaWjsvclient_ jsjs 


// 后 台 登 录 界面 验证 脚本 
function checkO{ 
if(login.usemame.value—""){ // 判 断 用 户 名 是 否 为 空 
alert(" 请 输入 用 户 名 !1"); 
login.usermame.focus(); // 将 光标 焦点 定位 到 该 表单 元 素 
returm false; 
} 
if(login.pwd.value==""){ /判断 用 户 密码 是 否 为 空 
alert(" 请 输入 密码 11"); // 如 果 为 空 ， 弹 出 提示 框 
login.pwd.focus(); // 将 光标 焦点 定位 到 该 表单 元 素 
retum false: /返回 false 


(2) 删除 确认 ， 当 要 执行 删除 操作 时 ， 使 用 JavaScript 脚本 文件 进行 确认 ， 以 免 因为 误 操 作 而 引 
起 不 必要 的 损失 。 
例 程 02 代码 位 置 ， 光盘 \TM\03\oa\js\client_js.js 


function cfm(){ 
if(confirm(' 确 认 要 删除 吗 ? ')) // 选 择 框 函 数 
retum true; // 如 果 选 择 确认 ， 则 返回 tue， 继 续 执 行 
else 
returmn false; // 否 则 ， 返 回 false 
} 


3.5.2” 自 定义 函数 


在 ine 文件 夹 下 ， 有 两 个 主要 文件 : chec.php 文件 和 func.php 文件 ， 其 中 chec.php 文件 是 权限 检查 
文件 ， 是 办 公 自 动 化 管理 系统 每 个 页 面 都 要 引用 的 ，func.php 文件 是 自 定义 函数 文件 。 

1. chec.php 文件 

对 办 公 自 动 化 管理 系统 来 说 ， 用 户 对 每 个 页 面 的 访问 都 要 有 该 页 的 权限 才 可 以 ， 如 果 没 有 权限 级 
别 的 限制 ， 随 意 访问 重要 的 资源 和 数据 ， 那 么 只 能 说 明 这 是 个 完全 失败 的 系统 。chec.php 文件 的 代码 
如 下 : 

例 程 03 代码 位 置 : 光盘 \TM\03\oa\inc\chec.php 


<?php 
session_start(); // 开 启 session 支 持 
© if(lisset($ SESSION[u name])) 
echo "<script>alert(' 您 无 权 访问 ");location="../index.php':</script>"; 
@ if(§ SERVERI'HTTP REFERER']=—"") 
echo "<script>alert(' 本 系统 不 允许 从 地 址 栏 访问 ");history.go(-1);</script>"; 
> 


“1. 
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< 代码 贴 十 

@ isset() 函 数 : 用 来 判断 session[u_ name] 是 否 被 创建 ， 如 果 session 已 经 创建 ， 返 回 true， 否 者 返回 人 false。 其 中 
session[u_name] 是 用 户 登 录 验 证 通过 后 创建 的 ， 如 果 没 有 登录 的 步骤 或 session 超时 ， 那 么 就 会 提醒 用 户 没有 权限 。 

四 $ SERVER[HTTP_REFERER]: 系统 预定 义 变量 ， 存 储 的 是 上 一 页 的 URL 地 址 。 这 个 判断 的 作用 是 防止 当前 用 
户 访问 不 属于 自己 权限 内 的 网 页 。 

2. func.php 文 件 

限于 篇 幅 ， 这 里 只 给 出 两 个 自 定义 函数 的 代码 和 说 明 ， 其 他 函数 请 到 光盘 中 自行 查看 。 

(1) 读 取 字 段 函 数 read_field0 

本 函数 的 作用 是 根据 传 入 的 id 值 取得 相关 的 字段 名 ， 一 共有 4 个 参数 ， 函 数 代码 如 下 : 

例 程 04 ”代码 位 置 ， 光盘 \TM\03\oa\inc\func.php 


function read field($conn,$tablename, $fieldname,S$n id){ 
$sqlstr = "select ".$fieldname." from ".$tablename." where id =".$n_id;  // 生 成 sql 语 句 


$result = mysql_query($sqlstr,$conn); // 执 行 sql 语 句 
Srows = mysql fetch_row($result); // 返 回 结果 集 
Tetum $rows[0]; // 返 回 需 要 的 字段 名 


} 
read_field() 函 数 的 参数 说 明 如 表 3.1 所 示 。 
表 3.1 read _field() 函 数 参 数 说 明 


数据 库 链接 资源 变量 
Sfeldname 
S$tablename 


要 查找 的 id 值 


(2) 处 理 消息 函数 re_message() 
本 函数 的 作用 是 返回 消息 结果 ， 一 共有 2 个 参数 ， 函 数 代码 和 参数 解释 如 下 : 
例 程 05 ”代码 位 置 ， 光 盘 \TM\03\oa\admin\inc\func.php 


function re message(S$result,$] address){ 
if($result) 
echo "<script>alert(' 操 作成 功 ! ');location=".$l_address.";</script>"; // 如 果 结 果 为 tue， 转 到 其 他 页 面 


else 
echo "<script>alert(' 系 统 繁忙 ， 请 稍 后 再 试 ');history.go(-1);</script>"; /如 果 结 果 为 false， 回 到 上 一 步 
| 
$result: 数据 库 返 回 结果 , 如 果 返 回 值 为 tue， 说 明 对 数据 库 的 操作 成 功 ; 如 果 返 回 值 为 false， 


说 明 操 作 失 败 。 
$1_address: 操作 成 功 后， 要 返回 的 url 地址。 


Se 
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3.6 ”前 人 台 首 页 设计 


对 于 一 个 办 公 自 动 化 管理 系统 来 说 ， 


首页 不 可 能 、 也 不 允许 显示 太 多 的 内 容 和 复杂 的 设计 ， 


因为 


办 公 自 动 化 管理 系统 的 作用 是 帮助 提高 企业 的 管理 效率 ， 职 员 的 工作 效率 。 如 果 页 面 过 于 繁琐 ,会 i 


只 员 分 不 清 主 次 ， 找 不 到 重点 。 


3.6.1 前 台 首 页 概述 


根据 用 户 对 各 个 功能 模块 
网 站 首页 导航 栏 : 包 
网 站 左 侧 导 航 栏 : 包 


> ”企业 信息 模块 : 
> ”企业 绩效 模块 : 
> ”人事 消息 模块 : 
> 审核 批示 模块 : 
> 考勤 管理 模块 : 
> 个 人 计划 模块 : 


> ”职员 天 地 模块 : 
网 站 主 显示 区 : 默认 


所 以 一 定 要 突出 重点 内 容 ， 显 示 关 键 功能 。 


的 使 用 频率 和 重要 程度 ,本 系统 的 首页 面 中 要 显示 的 模块 主要 有 3 部 分 : 


括 当 前 用 户 、 所 在 部 门 、 当 前 时 间 、 首 页 、 重 新 登录 和 退出 登录 。 
括 各 个 管理 模块 及 分 类 。 

包括 公司 简介 、 规 章 制度 、 组 织 结构 和 企业 管理 。 

包括 任务 绩效 、 质 量 绩效 和 绩效 评定 。 

包括 企业 公告 、 活 动 安排 和 消息 管理 。 

包括 发 布 审核 和 批示 审核 。 

包括 上 下 班 登记 、 病 事假 登记 、 加 班 登记 和 考勤 设置 。 

包括 工作 反馈 、 周 计划 、 月 计划 、 年 计划 和 任务 计划 。 

包括 职员 浏览 、 意 见 箱 和 个 人 设 定 。 

显示 企业 公告 、 活 动 安排 和 个 人 计划 和 批示 审核 。 


下 面 看 一 下 本 案例 中 提供 的 前 台 首页 ， 该 首页 在 本 书 光盘 中 的 路 径 为 \TM\03\oa\pub_main.php， 如 


图 3.16 所 示 。 


办 公 自 动 化 管理 


上 功能 分 类 导航 区 


田 办 企业 信息 
四 国企 业绩 效 
田 全 人 事 消息 
用 全 审核 批示 
用 办 考勤 首 理 
田 吉 个 人 计划 
田 但 职员 天 地 


企业 公告 
标题 
13 日 考试 2007-11-16 ”明天 下 午 3 点 ,羽毛球 第 三 过 抽签 
测试 到 斌 2007-12-04 测试 


个 人 计划 审核 批示 
日 期 内容 提要 类 型 日 期 标题 是 否 批 示 操作 
2007-12-17 本 月 25 日 截至 ,完成 影 . 查 看 全 立 任务 计划 | 2007-12-17 一 个 新 方向 未 审核 “修改 || 租 除 


2 次 测试 


2007-12-17 本 周 完 成 影视 在 贱 项 目 .查看 全 文 周 计 划 | 2007-12-17 统筹 规划 节约 资 未 审核 “修改 | | 扣除 


2007-12-05asdf. 查看 全 文 工作 反馈 


图 3.16 办公 自 动 化 管理 系统 前 台 首页 
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3.6.2 前台 首 页 技术 分 析 


目前 网 页 页 面 的 布局 主要 有 两 种 方式 : 表格 布局 与 框架 布局 。 本 系统 前 台 页 面 的 布局 使 用 的 是 框 
架 布局 。 框 架 布 局 就 是 可 以 将 容器 窗口 划分 为 若干 个 子 窗口 ， 每 个 子 窗口 可 以 分 别 显示 不 同 的 网 页 ， 
网 页 之 间 为 相互 独立 的 ， 没 有 直接 的 关联 ， 又 由 一 个 网 页 将 这 些 分 开 的 网 页 组 成 一 个 完整 的 网 页 ， 显 
示 在 浏览 者 的 浏览 器 中 。 框 架 布局 的 好 处 是 : 每 次 浏览 者 发 出 对 页 面 的 请 求 时 ， 只 下 载 发 生变 化 的 框 
架 页 面 ， 其 他 子 页 面 保持 不 变 。 使 用 框架 可 以 非常 方便 地 完成 导航 工作 。 

下 面 来 具体 看 一 下 框架 布局 的 使 用 格式 及 属性 。 

1. 框架 布局 格式 

框架 布局 的 格式 很 简单 ， 只 要 几 行 代码 即 可 ， 常 用 的 格式 如 下 : 


<html> 
<head> 


</head> 
<frameset> 
<frame> 
<frame> 
</frameset> 
<noframes> 
<body> 
</body> 
</noframes> 
</html> 
其 中 <frameset> 和 <frame> 标 签 是 框架 集 标 记 ， 而 <noframes> 标 签 是 为 了 防止 浏览 器 不 支持 框架 而 
实行 的 一 种 补救 措施 。 如 果 浏 览 器 不 支持 框架 集 ， 就 会 执行 <noffames> 标 记 里 的 内 容 ， 让 用 户 能 够 正 
常 浏览 网 页 。 
2. 框架 集 属性 
框架 集 包含 各 个 框架 的 信息 ， 通 过 <frameset> 标 记 来 定义 。 框 架 是 按照 行 和 列 来 组 织 的 ， 可 以 使 用 


表 3.2 所 示 。 
表 3.2 框架 集 的 常用 属性 


属性 名 称 属性 说 明 应 用 举例 
在 水 平方 向 上 将 浏览 器 分 割 成 多 个 窗口 ， 取 | <frameset cols="25%,100,*"> 
COLS 值 有 3 种 形式 : 像素 、 百 分 比 〈%) 和 相对 尺 | <frame></frame> 


寸 (*) </frameset> 

<frameset rows="25%,100,*" > 
在 垂直 方向 上 将 浏览 器 分 割 成 多 个 窗口 ， 取 | <frame> 

值 和 COLS 类 似 ， 也 是 3 种 形式 <frame> 


</frameset> 
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续 表 
属性 名 称 应 用 举例 
Eo 指定 框架 周围 是 否 显示 边框 , 取信 为 1 (显示 <framset cols="25%,*" cols="*" frameborder="0"> 
边框 ， 默 认 值 ) 或 0 (不 显示 边框 
</frameset> 
<framset cols="25%,*" cols="*" 
A 指定 框架 之 间 的 间隔 ， 以 像素 为 单位 。 默 认 | framespacing="1"> 
是 无 间隔 的 
</frameset> 
<framset cols="25%,*" cols="*" frameborder="1" 
Dolpa 指定 边框 的 宽度 , frameborder 属 性 为 I 时 该 属 | border="5"> 
性 才 有 效 0 
</frameset> 
3. 框架 属性 


使 用 FRAME 标记 可 以 设置 框架 的 属性 ， 包 括 框架 的 名 称 、 框 架 是 否 包 含 滚动 条 以 及 在 框架 中 显 
示 的 网 页 等 。 FRAME 标记 的 常用 属性 及 其 说 明 如 表 3.3 所 示 。 


表 3.3 ”框架 的 常用 属性 


属性 名 称 属性 说 明 
NAME 指定 框架 的 名 称 
SRC 指定 在 框架 中 显示 的 网 页 文件 (包括 HTML、PHP、JSP 等 网 页 文件 ) 
FRAMEBODER 指定 框架 周围 是 否 显示 边框 ， 取 值 为 1 (显示 边框 ， 为 默认 ) 或 0( 不 显示 边框 
NORESIZE 可 选 属性 ， 若 指定 了 该 属性 ， 则 不 能 调整 框架 的 大 小 
SCROLLING 指定 框架 是 否 包含 滚动 条 。 属 性 可 以 是 yes (有 ) 、no (没有 ) 和 auto( 自 由 ) 


3.6.3 ”前台 首页 的 实现 过 程 


国 ”前台 首页 使 用 的 数据 表 : tb_users、tb_list、tb_person、tb_register、tb_plan 
办 公 自 动 化 管理 系统 的 前 台 首 页 采用 的 二 分 栏 结构 布局 ， 二 分 栏 布局 的 特点 是 简洁 、 大 气 、 个 性 
鲜明 ， 其 框架 设计 依据 其 内 容 形 式 的 变化 而 灵活 多 变 ， 结 构 简练 。 非 常 符 合 办 公 自 动 化 管理 系统 的 风 
格 ， 本 系统 中 框架 布局 的 具体 应 用 如 下 。 
例 程 06 ”代码 位 置 : 光盘 \TM\03\oa\pub_main.php 
<frameset rows="111,*" cols="*" frameborder="no" border="0" framespacing="0"> 
<frame src="top.php" name="topFrame" scrolling="No" noresize="noresize" id="topFrame" title="topFrame" /> 

<frameset rows="*" cols="220,*" framespacing="0" frameborder="not" border="0"> 

<frame src="left.php" name="leftFrame" scrolling="auto" noresize="noresize" id="leftFrame" title="leftFrame" /> 

<frame src="main.php" name="mainFrame" scrolling="auto" id="mainFrame" title="mainFrame" /> 

*，155。 乡 


</frameset> 
</frameset> 
<noframes><body> 
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</body> 
</noframes> 


< 代码 贴 二 
@ rows="111,*" cols="*": 定义 顶部 框架 。 
@ src="top.php": 定义 顶部 框架 内 显示 的 页 面 。 
图 rows="*" cols="220,*": 定义 下 部 左 侧 框 架 。 
@ src="leftphp": 定义 左 侧 框架 显示 的 页 面 。 
@ src="main.php": 定义 中 间 主 框架 显示 的 页 面 。 
@ <noframes>: 当 浏览 器 不 支持 框架 集 时 的 内 容 。 


3.7 ”人 事 消息 模块 设计 


人 事 消 息 模块 主要 是 对 文件 的 收发 管理 ， 模 块 的 设计 和 实现 并 不 是 十 分 复杂 ， 但 在 整个 系统 中 的 
位 置 却 很 重要 。 因 为 公告 栏 和 意见 箱 面向 的 是 全 体 用 户 ， 企 业 的 最 新 动向 和 职员 的 意见 想法 首先 都 是 
在 这 里 体现 出 来 的 。 
3.7.1 人事 消息 模块 概述 


人 事 消息 模块 主要 包含 了 两 部 分 内 容 ， 一 部 分 是 面向 全 体 用 户 的 ， 包 括 查 看 公告 、 活 动 、 意 见 箱 
等 ， 一 部 分 是 仅 对 人 事 部 开放 ， 其 他 用 户 不 允许 、 也 不 会 看 到 的 页 面 ， 如 公告 管理 、 意 见 管理 等 。 下 


面 给 出 人 事 消息 框架 如 图 3.17 所 示 。 


用 户 
ss RN | 
回复 留言 人 一 
CD — 5 


发 布 公告 5 | 
超级 用 户 LS 普通 用 户 


图 3.17 人 事 消息 用 例 图 
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3.7.2 ”人 事 消息 模块 技术 分 析 


在 人 事 消息 模块 中 ， 企 业 公告 和 活动 安排 都 是 在 同一 显示 页 中 显示 (pP_message.php) ， 为 了 区 分 
不 同 的 操作 ， 需 要 给 显示 页 (p_message.php) 传 一 个 u_id 值 ， 在 数据 表 中 根据 不 同 的 u_id 值 ， 取 得 不 
同类 别 的 内 容 。 传 值 方式 有 url 传 值 方式 〈 如 p_message.php?u_id=1 ) 和 表单 传 值 方式 。 

同样 的 ， 在 接收 页 中 ， 接 收 方式 也 有 两 种 : get 方式 和 post 方式 。PHP 中 使 用 预定 义 变量 $_GET 
和 $_POST 来 接收 传 值 ， 格 式 为 : 

$_GET/POST[u_id]; /注意 ， 变 量 名 都 为 大 写 


对 于 url 传 值 方式 ， 接 收 页 始终 用 $_GET[] 变 量 来 接收 ， 如 果 使 用 form 表单 传 值 ， 那 么 就 看 form 
表单 中 method 属性 的 设置 了 。 如 果 method=get, 就 使 用 $_GET[] 变 量 ; 如 果 method=post, 就 使 用 $_POST[] 
变量 。 

PHP 对 传 值 方式 和 接收 方式 规定 很 严格 ， 用 $_POST[u_id] 接 收 不 了 p_message.php?u_id=1 传 过 来 
的 参数 。 同 样 的 ， 用 $_GET[u_id] 也 接收 不 着 method=post 的 表单 元 素 值 。 


全 注意 : 如 果 在 php.ini 配置 文件 中 GLOBAL=ON/OFE 这 行 的 值 为 ON， 那么 直接 写 $name 就 可 以 调 
用 表单 元 素 的 值 ， 而 不 区 分 get 和 post; 如 果 为 OFF， 则 不 可 以 。 直 接应 用 表单 名 称 十 分 方 
便 ， 但 也 存在 着 安全 隐患 。 推 荐 关闭 GLOBAL。 


3.7.3 消息 管理 的 实现 过 程 


国 ”消息 管理 模块 使 用 的 数据 表 : tb_person 

单 击 “ 人 事 消 息 ” 下 拉 列 表 的 “消息 管理 ”， 在 主 框架 (mainFrame) 内 就 会 显示 消息 管理 页 面 ， 
在 页 面 中 显示 了 发 布 过 的 消息 列表 和 对 消息 的 操作 ， 包 括 “修改 ”、“ 删 除 ” 和 “发 布 新 消息 ”。 消 
息 管 理 页 面 的 运行 结果 如 图 3.18 所 示 。 


消息 管理 
发 时间 本题 染 作 
2007-11-i6 明天 下 午 3 点 ， 羽毛 于 第 三 较 扯 答 ER 有 除 
四 活 1 日 考试 Ma/ 
上 @ 滑 和 管理 发 于 有 
用 站 市 仿 批 示 
田间 考 双 和 理 
加 站 人 计划 
加 I 天 直 


图 3.18 消息 管理 页 面 运行 结果 


在 本 页 面 中 ， 系 统 首先 通过 权限 检查 文件 chec.php) 判断 用 户 是 否 为 登录 用 户 、 是 否 为 非法 链接 。 
如 果 被 系统 判断 为 非法 操作 ， 系 统 将 直接 关闭 ， 如 果 没 有 异常 情况 ， 系 统 才 继续 执行 下 面 的 代码 在 后 


7. 
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面 的 例 程 中 ， 几 乎 每 个 页 面 都 有 chec.php 文件 ， 如 果 不 是 特殊 说 明 ， 则 都 为 正常 登录 ， 到 时 将 不 再 具体 

说 明 ) ， 当 用 户 通过 检查 后 ， 系 统 将 访问 数据 库 ， 从 人 事 消息 数据 表 中 〈tb_person) 读 取出 消息 发 布 时 

间 、 消 息 标题 ， 显 示 在 页 面 中 ， 并 通过 id 为 每 条 数据 设置 “修改 ”和 “删除 ” 操作。 程序 关键 代码 如 下 : 
例 程 07 ”代码 位 置 : 光盘 \TM\03\oa\rsxx\p_manage.php 


<?php 
session_start(); /开启 session 
include "../inc/chec.php"; /包含 权限 检查 文件 
include "../conn/conn.php"; /包含 数据 库 连接 文件 
> 
<link href="../css/style.css" rel="stylesheet" /> // 引 入 外 部 CSS 样 式 文件 
<script sre="../js/client js.js"></script> // 引 入 js 文件 
<?php 
* 显 示 全 部 消息 记录 */ 
$sqlstr = "select id,p_time,p_title from tb_person"; /生成 sql 语 句 @ 
$result = mysql_query($sqlstrSconn); /执行 sql 语 句 ， 生 成 结果 集 
while($rows = mysql_fetch_row($resulb){f /| 循环 输出 结果 集 记录 
echo "<tr>"; 


for($i=1;$i<count($rows);$i++){ 
echo "<td height=30 style='text-indent: 30px;>".Srows[S$i]."</td>"; 


} 
echo "<td><a href="'m_message.php?id=".Srows[0]."> 修 改 </a>/<a 
href="'d_message_chk.php?id=".Srows[0]."" onclick="return del_mess();> 删 除 </a></td>"; 


echo "</tr>";} 
/类 党 突 光 突 突 类 突 尖 兴安 类 突 突 光 突 尖 兴安 闪 突 突 灾 突 灾 内 / 
> 
<t> 


<td height="30" align="right" valign="middle" colspan="3"><a href='add_manage.php' target="mainFrame"> 发 
布 新 消息 </a></td> 
</t> 


下 面 分 别 介绍 “添加 新 消息 ”、“ 修 改 ” 和 “删除 ”消息 的 实现 过 程 。 
1. 发 布 新 消息 
单 击 “ 发 布 新 消息 ” 超 链接 ， 进 入 发 布 页 面 。 发 布 消息 页 面 的 运行 结果 如 图 3.19 所 示 。 


DH | 添加 补 息 
= 有 


辣 关 下 和 1 二 天 全 ， 玉 全 本 亡 这 和 4 负 交 委 。 
| 吕 交 组 的 冠 亚军 名 有 产生。 让 我 们 拭 是 以 竺 吧 。 


EE 


[ET 


图 3.19 ”发 布 消息 页 面 运行 结果 
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发 布 页 面 中 ， 主 要 包含 一 个 消息 表单 元 素 ， 部 分 表单 元 素 如 表 3.4 所 示 。 
表 3.4 发布 消 息 页 面 的 主要 表单 元 素 


名 称 | 元 素 类 型 重要 属性 含义 
addmess form | action="add_manage_chk.php" method="post" id="addmess" | 发 布 消息 表单 
_Putitle text | name="p_title" id="p_title" | 消息 标题 
content textarea name="p_content" id="p_content" cols="60" rows="15" 消息 内 容 
<option value="9"> 企 业 公告 </option> a 
ptype ns es value="10"> 活 动 pn 消息 类 型 
submit2 submit value=" 发 布 " onclick="return add_mess():" “发 布 ”按钮 


在 消息 页 面 中 输入 消息 的 相关 内 容 后 ， 单 击 “ 发 布 ”按钮 ， 系 统 将 会 跳 到 消息 处 理 页 
(add_manage_chk.php) 进行 处 理 ， 将 消息 存储 到 数据 库 中 ， 然 后 再 返回 该 页 。 程 序 关 键 代码 如 下 : 
例 程 08 ”代码 位 置 ， 光盘 \TM\03\oa\rsxx\add_manage_chk.php 


<?php 
session_start(); // 开 启 session 
include "../inc/chec.php"; // 包 含 权 限 检查 文件 
include "../conn/conn.php"; // 包 含 数据 库 链接 文件 
include "../inc/func.php"; // 包 含 函 数 处 理 文件 
必 添 加 新 消息 %/ 


$sqlstr = "insert into tb person values(",".$ POSTI[p title].",".$ POST[p content].",now(),".$ POST[p typel].")"; 
$result = mysql query($sqlstr,$conn); 
re_message(Sresult,"p_manage.php"); // 消 息 处 理 函 数 


/ 兴 当 风灾 光源 内 风 兴 风灾 内 ] 


?> 
2. 修改 消息 
消息 发 布 后 ， 可 以 随时 对 消息 内 容 进行 修改 。 在 消息 管理 页 面 中 ， 选 择 要 修改 的 消息 列 ， 单 击 修 
改 超 链接 将 进入 消息 修改 页 面 。 在 消息 修改 页 面 中 ， 有 一 个 和 发 布 页 面 非常 相似 的 “修改 ”表单 。 消 
息 修 改 页 面 中 的 主要 表单 元 素 如 表 3.5 所 示 。 
表 3.5 修改 页 面 的 表单 元 素 


名 称 | 元 素 类 型 重要 属性 含 义 
addmess form action="m _message chk.php" method="post" 修改 消息 表单 
_p title text value="<?php echo Srows[1]: ?>" 消息 标题 


_P_content textarea <?php echo $rows[2]; > 消息 内 容 
<?phpif($rows[4] 一 "9"){?> 
<option value="9" selected="selected"> 企 业 公告 </option> 
<option value="10"> 活 动 安排 </option> 
p_type select <?php}else{?> 消息 类 型 
<option value="9"> 企 业 公告 </option> 
<option value="10" selected="selected"> 活 动 安 排 </option> 
<?php}?> 


id hidden value="<?php echo $rows[0]: ?>" 修改 消息 id 


submit2 submit Value=" 修 改 " onclick="retum add_messO:" “修改 ”按钮 
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消息 修改 完成 后 ， 单 击 “ 修 改 ” 按 钮 在 m_message_chk.php 页 中 将 会 处 理 修改 事件 ， 通 过 隐藏 表 
单传 过 来 的 id 定位 到 要 修改 的 消息 项 ， 使 用 update 语句 实现 对 数据 的 更 新 。 程 序 关 键 代 码 如 下 : 
例 程 09 ”代码 位 置 : 光盘 \TM\03\oa\rsxx\m_message_chk.php 


<?php 
session_start(); // 开 启 session 
include "../inc/chec.php"; // 包 含 权限 检查 文件 
include "../conn/conn.php"; // 包 含 数据 链接 文件 


/* 更 新 数据 库 */ 
$sqlstr = "update tb person setp title=".$ POSTIp title].",p content=".$ POST[p content].",p time= now(),u id= 
".$ POSTIp typel." where id=".$ POST[id]; 


Sresult = mysql query($sqlstr,$conn); 
re_message(Sresult,"p_manage.php"); 
/ 放 实 认识 家 当 实 风灾 风灾 风光 


es 


3. 删除 消息 


// 消 息 处 理 函 数 


最 后 来 看 一 下 删除 操作 。 每 隔 一 段 时 间 管 理 员 就 要 定期 清理 一 下 无 用 的 消息 和 活动 安排 。 以 加 速 
页 面 的 浏览 速度 ， 减 轻 服务 器 压力 。 删 除 消息 的 运行 结果 如 图 3.20 所 示 。 
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+ 功能 分 类 导航 区 


图 办 企业 信息 | 消息 管理 
田 各 企业 绩效 发 布 时 间 标题 
一 人 事 浓 息 2007-11-16 | 。 明天 下 午 3 点 ， 羽毛 于 第 三 
I- 国企 业 公告 | 上 - 
|- 四 活动 安排 2007-11-15 13 日 等 斌 
硬汉 让 管理 2007-11-27 Er 
Es a 
i 2) MAR? 
ni EE _w | 
图 移 个 人 计划 
困 和 职员 天 地 


图 3.20 ”删除 操作 的 运行 结果 图 


删除 消息 时 ， 选 择 要 删除 的 消息 列 ， 单 击 “ 删 除 ” 超 链接 ， 弹 出 确认 删除 对 话 框 ， 单 击 “确定 ” 
按钮 将 要 删除 消息 的 id 号 传 给 系统 ， 通 过 消息 处 理 函数 将 消息 删除 。 关 键 代 码 如 下 : 
例 程 10 ”代码 位 置 : 光盘 \TM\03\oa\rsxx\d_message_chk.php 


<?php 
session_start(); // 开 启 session 
include "../inc/chec.php"; // 包 含 权限 检查 文件 
include "../conn/conn.php"; // 包 含 数据 库 链 接 文 件 
include "../inc/func.php"; // 包 含 函数 处 理 文件 


/删除 数据 六 


So. 


$sqlstr = "delete from tb_person whereid= ".$_GET[id]; 
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$result = mysql_query($sqlstr,$conn); 
re_message(Sresult,"./p_manage.php"); 。“”// 消 息 处 理 函 数 


/ 突 光 灾 光 交 光 光 光 央 / 


3.7.4 意见 箱 的 实现 过 程 


国 ”意见 箱 模 块 使 用 的 数据 表 : tb lyb 
意见 箱 是 用 户 匿 名 发 言 的 一 个 留言 板 。 对 于 用 户 的 留言 ， 只 有 人 事 部 的 人 员 才 有 权 回 复 或 删除 ， 
对 于 其 他 部 门 的 员工 则 只 是 可 以 留言 和 查看 , 而 无 法 进行 其 他 操作 。 意见 箱 的 运行 结果 如 图 3.21 所 示 。 


办 公 自 动 化 管理 系统 


上 功能 分 类 导航 区 


用 
el ee 
加 办 企 业绩 多 
田 地 人 事 消息 peor!i-1e 主题 : 今天 的 饭 大 好 吃 了 同 复 。 册 除 
国内 审核 批示 
+ 莹 勒 管 理 今天 的 饭 太 好 吃 了 ， 没 有 吃 够 啊 
加 着 个 人 计划 
职员 天 地 出 谢 作 的 意见 ， 今 天 一 定 多 做 点 "Y 
-OMB poor-u-e 主题: 出 地 回复 出 除 
[| 
|- @ 个 人 设 定 
意见 箱 测试 + 测试 成 功 
S55555555 
E:T 
| 名 不 能 准备 两 不 衣架 用 家 原 啊 o_o7 习 
容 : 
习 
到 | 


图 3.21 意见 箱 页 面 的 运行 结果 
在 本 页 面 中 ， 系 统 首先 读 取出 意见 箱 数据 表 (tb_ lyb) 中 的 所 有 数据 ， 并 逐条 显示 ， 在 每 条 显示 记 
录 后 ， 有 一 个 判断 式 ， 判 断 用 户 所 属 部 门 是 否 为 人 事 部 ， 如 果 是 人 事 部 成 员 ， 将 显示 “回复 ”和 “ 删 
除 ” 超 链接 ， 如 果 不 是 人 事 部 ， 则 不 显示 这 两 个 操作 。 这 里 是 强制 性 的 ， 也 就 是 说 ， 即 使 是 管理 员 ， 
也 无 法 设置 这 里 的 权限 ， 只 有 开发 人 员 才 可 以 改变 。 如 果 想 使 用 这 种 技术 ， 就 一 定 要 确保 这 项 功能 权 
限 不 会 轻易 的 更 改 。 下 面 给 出 意见 箱 页 面 的 关键 代码 。 
例 程 11 代码 位 置 : 光盘 \TM\03\oa\zytd\lyb.php 


<?php 

session_start(); /开启 session 支 持 
include "../conn/conn.php"; /包含 数据 库 链 接 文件 
include "../inc/chec.php"; /包含 权限 检查 文件 
include "../inc/func.php"; /包含 自 定义 函数 文件 


/显示 意见 箱 信息 六/ 
“161。 g 
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$1_sql= "select id,l_title,L_ contentl time,is_reply,r_back from tb lyb order by id desc"; 
$l_rst = mysql_query($]_sql,$conn); 


while($l rows = mysql_fetch_array($L rsb)){ /开始 循环 输出 每 条 记录 
> 
<tr> 
<td width="15%" height="30" align="left" valign="middle" scope="col"> 
<?php echo $1_rows[l time]; ?> 
</td> 
<td align="left" valign="middle" scope="col"> 
主题 : <?php echo $1_rows[l_title]; ?> 
</td> 
<!-- 判断 登录 用 户 是 否 为 人 事 部 成 员 --> 
<td width="15%" align="center" valign="middle" scope="col"> 
<?php if(($_SESSION[u_depart]) 一 "人 事 部 "){ ?> 
<!-- 当 登录 用 户 是 人 事 部 成 员 时 ， 显 示 可 执行 操作 --> 
<a href="t_back.php?id=<?php echo $1_rows[id]; ?>"> 回 复 </a>&nbsp;&nbsp;<a href="del_ly_chk.php?id=<?php 
echo $1_rows[id]; ?>" onclick="retum del_mess("> 删 除 </a> 
<?php } 
?>&nbsp; 
</td> 
<<!-- > 
</tr><tr> <td height="75" colspan="3" align="left" valign="middle" scope="col" > 
<?php echo $1_rows[l_content]; ?> 
</td></tr> 
<?php 
<!-- 当 字段 is_reply 的 值 为 1 时 ， 说 明 有 有 回复 信息 --> 
if($1_rows[is_reply] 一 1){ 
> 
<tr> 
<td height="25" colspan="3" align="left" valign="middle" headers="50" scope="col" 
onmouseover="this.style.backgroundColor=#FFEEBC" onmouseout="this.style.backgroundColor=""> 
<font color="#FF0000"> 
<!-- 显 示 回 复 信息 -> 
<2php echo $l rows[r_back]; ?> 
</font></td> </tr> 
<?php}} 
/详实 突 光 实 炎 实 光 容光 实 实 光 光 / 
?><table> 
<! 一 留言 菜单 一 > 


下 面 介绍 匿名 留言 和 

1. 匿名 留言 

留言 页 面 主 要 是 一 个 HTML 表单 ， 因 为 允许 匿名 留言 ， 所 以 表单 中 没有 隐藏 域 ， 该 页 面 中 的 表单 
元 素 列 表 如 表 3.6 所 示 。 


Se 


El 


复 、 删 除 留 言 的 实现 过 程 。 
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表 3.6 留言 页 面 的 菜单 表单 元 素 表 


lyb id="lyb" name= "lyb" method="post" action="lyb_chk.php” 
1 title | text | type="text" name="] title" size="30" | 意见 主 
1 content | textarea | name="1 content" cols="75" rows="10" | 意见 内 容 


Submitl hidden type="reset" value=" 重 置 " 


Submit type="submit" value=" 提 交 " onclick="retum add_lyb0); 


当 用 户 填 写 完 意见 标题 和 意见 内 容 后 ， 单 击 “ 提 交 ” 按 钮 ， 发 布 意见 ， 系 统 将 转 到 意见 处 理 页 
(lyb_chk.php) 中 对 意见 进行 处 理 : 如 果 意 见 标题 和 意见 内 容 都 不 为 空 , 则 执行 insert 语句 , 向 表 tb_ lyb 
中 添加 一 条 新 数据 。 程 序 关键 代码 如 下 : 


<?php 
session_start(); // 开 启 session 支 持 
include "../conn/conn.php"; // 包 含 数据 库 链接 文件 
include "../inc/chec.php"; // 包 含 权 限 检查 文件 
include "../inc/func.php"; // 包 含 自 定义 函数 文件 


人 # 判断 输入 是 否 为 空 ， 如 果 为 空 ， 则 返回 ， 如 果 无 错误 ， 则 执行 insert 语 句 添加 新 记录 */ 
if((trim($ POSTIIL title]) {= "") and (trim($ POSTIL content]) {= ""){ 
$1 sql= "insert into tb lyb values(",".$ POSTI[1 title].",".$ POSTI1 content].",now(),",")"; 
$1 rst = mysql query($l sql,$conn); 


Te_message($l_rsb"lyb.php?u_id=24"); // 使 用 自 定义 函数 
人 突 实 实 灾 灾 灾 实 突 实 突 内 突 尖 洋溢 实 央 内 灾 灾 灾 突 灾 实 灾 实 实 实 实 实 突 窑 实 实 实 内 内 突 奖 实 奖 实 实 灾 实 灾 实 实 灾 灾 实 实 实 实 风 内 实 实 风灾 风 突 灾 灾 灾 灾 洋洋 灾 实 实 灾 实 六/ 
} 
else 
echo "<script>alert(' 内 容 和 消息 不 允许 为 空 ");history.go(-1);</script>"; 
ea 


2. 回复 、 删 除 留言 操作 

在 意见 箱 页 面 中 ， 当 系统 判断 当前 登录 用 户 为 人 事 部 成 员 后 ， 将 显示 留言 信息 后 面 的 、 可 操作 的 
功能 模块 ， “回复 ”和 “删除 ”。 单 击 相应 留言 主题 后 面 的 “回复 ” 超 链 接 ， 进 入 回复 留言 页 面 。 回 
复 留言 页 面 的 运行 结果 如 图 3.22 所 示 。 
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图 3.22 回复 页 面 的 运行 结果 
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回复 留言 页 面 中 的 主要 表单 元 素 如 表 3.7 所 示 。 
表 3.7 留言 回复 表单 的 主要 元 素 表 


名 称 | 元 素 类 型 重要 属性 含义 
tback | form | action="t_back_chk.php" method="post" | 可 复 留言 表单 
ttitle | text | value="<?php echo read field($conn,"tb lyb","] title",$ GET[id)); ?>" | 意见 主题 

r back textarea name="r back" id="r back" cols="75" rows="10" 可 复 内 容 

id hidden name="id" value="<?php echo $_ GET[idj; ?>" 本 复 消息 id 
submit2 submit value=" 回 复 " onclick="retum re back0):" “回复 ”按钮 


在 回复 留言 页 面 中 ， 当 用 户 输入 回复 信息 后 ， 单 击 “ 回 复 ” 按 钮 ， 提 交 表 单 ， 在 表单 处 理 页 
(t_back_chk.php〉 中 系统 将 会 根据 回复 信息 ， 更 新 表 记 录 。 关 键 代码 如 下 : 
例 程 12 ”代码 位 置 ， 光盘 \TM\03\oa\zytd\ t_back_chk.php 


<?php 

session_start(); /开启 session 支 持 
include "../conn/conn.php"; /包含 数据 库 链接 文件 
include "../inc/chec.php"; /包含 权限 检查 文件 
include "../inc/func.php"; /包含 自 定义 函数 文件 


* 根 据 id， 更 新 数据 库 */ 

$sqlstr = "update tb_lyb set r_back=".$_POST[r_back].",is_reply = 1 where id =".$_POSTT[id]; 
$result = mysql_query($sqlstr, $conn); 

re_message($result,"lyb.php?u_id=24"); // 信 息 函 数 


/ 兴 认 党 尖 突 党 内 家 内 内 突 突 实 宙 安 突 尖 实 突 / 

人 > 

对 于 不 需要 再 保留 的 留言 信息 ， 可 将 其 删除 。 单 击 相应 消息 主题 后 面 的 “删除 ” 超 链接 ， 弹 出 确 
认 删 除 提示 对 话 框 ， 单 击 “ 确 定 ”按钮 将 消息 的 id 传 给 系统 ， 通 过 SQL 语句 将 其 删除 。 程 序 关键 代码 
如 下 : 

例 程 13 ”代码 位 置 ， 光盘 \TM\03\oa\zytd\del_ly_chk.php 


<?php 

session_start(); // 开 启 session 支 持 
include "../conn/conn.php"; // 包 含 数据 库 链 接 文件 
include "../inc/chec.php"; // 包 含 权 限 检 查 文件 
include "../inc/func.php"; // 包 含 自 定义 函数 文件 
$sqlstr = "delete from tb_lyb where id =".$_GETI[id]; // 删 除 信息 的 sq 语句 
$result = mysql_query($sqlstr,$conn); // 执 行 语句 
re_message($result,"lyb.php?u_id=24"); // 返 回 结果 

> 


3.8 ”考勤 管理 模块 设计 


考勤 功能 是 办 公 自动 化 管理 系统 中 每 天 都 要 使 用 到 的 功能 模块 之 一 ， 也 是 比较 重要 的 模块 之 一 。 
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除了 包括 正常 的 上 下 班 登记 功能 外 ， 还 要 包括 病 事假 登记 和 加 班 登记 等 特殊 登记 功能 。 管 理 员 通 过 考 
勤 记录 实现 对 上 下 班 及 加 班 标准 时 间 的 设置 。 


3.8.1 考勤 管理 模块 概述 


考勤 模块 主要 的 功能 有 : 

回 上 下 班 登记 : 包括 上 班 登记 和 下 班 登记 。 

病 事假 登记 : 包括 病假 登记 和 事假 登记 。 

回 “加班 登 记 : 包括 加 班 上 班 登记 和 加 班 下 班 登 记 。 

考勤 记录 : 包括 上 下 班 标准 时 间 设置 和 加 班 标准 时 间 设 置 。 
考勤 模块 的 活动 图 如 图 3.23 所 示 。 


图 3.23 考勤 管理 活动 图 


PHP 项 目 开发 全 程 实录 


3.8.2 考勤 管理 模块 技术 分 析 


在 PHP 中 查询 数据 表 中 数据 的 一 般 步 骤 为 : 
(1) 链接 数据 库 〈 链 接 文件 conn.php) 。 
(2) 执行 SQL 语句 ， 返 回 查 询 结果 集 ($result = mysql_query($sqlstr,$conn)。 
(3) 配合 while 循环 语句 输出 查询 结果 (while($rows = mysql_fetch_row($resulb)) 。 
(4) 关闭 数据 库 。 
在 步骤 〈3) 中 ， 如 果 要 取得 某 个 字段 的 值 ， 使 用 $rows[$num] 即 可 。 但 通过 图 3.23， 读 者 可 以 发 
现 , 从 开始 登记 到 保存 登记 记录 , 虽然 只 是 一 个 功能 的 实现 , 却 要 进行 至 少 3 次 判断 。 如 果 都 用 “0,1,2…” 
做 数组 下 标 ， 过 一 段 时 间 后 ， 根 本 记 不 起 取得 的 数据 是 什么 、 有 什么 作用 。 在 后 期 测试 和 系统 维护 时 ， 
还 要 逐一 地 查找 数据 表 来 比 对 。 除 了 mysql_fetch_rows0 函 数 外 ，php 还 提供 了 其 他 相似 的 函数 ， 下 面 
就 来 学 习 一 下 。 
1. mysql_fetch_array() 函 数 
mysql_fetch_array() 函 数 的 用 法 和 mysql_fetch_row() 函 数 的 用 法 十 分 相似 ， 唯 一 不 同 的 是 结果 集 的 
数组 下 标 是 所 查找 的 数据 表 的 字段 值 。 
例如 ， 读 取 数 据 表 tb_register 中 的 “登记 时 间 ” 字 段 ， 代 码 如 下 : 
$str = $rows[r_time]; 
这 样 ， 即 使 时 间 间 隔 比较 长 ， 甚 至 换 人 开发 ， 也 能 明白 该 变量 的 含义 。 
2.mysql_fetch_object() 函 数 
mysql_fetch_object() 函 数 与 其 他 两 个 函数 的 最 大 不 同 就 在 于 : 获取 的 结果 集 是 以 对 象 的 形式 存储 
的 ， 而 不 是 数组 的 形式 。 也 就 是 说 在 读 取 字段 变量 时 所 使 用 的 格式 不 再 是 $rows[$num] 了， 代码 如 下 : 


$str = $rows-->r_time; 


下 面 来 看 一 个 实例 ， 分 别 使 用 上 面 3 种 不 同 的 函数 来 获取 数据 表 tb_setup 的 id 值 ， 代 码 如 下 : 

<?php 

/# ”链接 数据 库 */ 

$conn = mysql_connect("localhost","root","root"); 

mysql_select_db("db_office", $conn); 

mysql_query("set names gb2312"); 

人 # ”创建 和 执行 sql 语 名 */ 

$sqlstr = "select * from tb_setup"; 

$result = mysql_query($sqlstr,$conn); 

/# ”使 用 mysql_retch_rows0 函 数 输出 字段 值 */ 

$rows_1 =mysql fetch_row(S$result); 

S$str = "mysql_fetch_rows 函 数 :".$Srows_1[0]."<br>"; 

/# ”使 用 mysql_retch_array0 函 数 输出 字段 值 */ 

$rows_2 =mysql fetch array(S$result); 

$str =="mysql_fetch_array 函 数 :".$rows_2[id]."<br>"; 

族 ”使 用 mysql_retch_object0 函 数 输出 字段 值 */ 


$rows_3 =mysql fetch_object(S$result); 
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$str = "mysql_fetch_object 函 数 : ".Srows_3->id."<br>"; 
echo "<script>alert(".$str."");</script>"; 
?> 


输出 结果 为 : 


mysql_fetch_rows 函 数 : 1 
mysql_fetch_array 函 数 : 2 
mysql_fetch_object 函 数 : 3 


3.8.3 ”上 下 班 登 记 的 实现 过 程 


国 ”上 下 班 登录 使 用 的 数据 表 : tb_register 
单 击 “ 考 勤 管理 ”菜单 中 的 “上 下 班 登记 ”， 在 主 显示 区 (mainFrame) 内 显示 个 人 上 下 班 的 登记 
记录 和 上 下 班 登记 链接 , 用 户 可 以 在 这 里 进行 登记 和 查找 。 上 下 班 登记 页 面 的 运行 结果 如 图 3.24 所 示 。 


上 功能 分 类 导航 区 
用 广 石 芷 
田 办 企业 信息 EE 
上 下 班 登记 
田 办 企业 绩效 
国生 上 下 碍 生 记 
本 六 二 本 本 机 而 本 区 到 |。 登记 状态 |， 各 广 
ed 2007-11-17 17:10:00 下 班 | “四 | 醒 肥 
了 a007-11-18 | 09:39:15 证 | ET | 无 
OETHEE 

-- 加 病 事假 登记 2007-11-18 10:02:23 上 班 | 迟到 | i 

|- 图 加 班 登 记 2007-11-18 10:06:32 上 班 | 。 壕 到 | saf 
Ce 则 寺 惑 记录 2007-11-18 10:07:08 上 班 | 迟到 | asdf 
证 | 007-11-18 | 10:07:15 | 得 | 9 | sad 
田 办 职员 天 地 


图 3.24 上 下 班 登 记 的 运行 结果 
在 上 下 班 登记 页 面 中 ， 通 过 登录 用 户 id， 从 数据 表 tb_register 中 返回 用 户 的 登记 记录 集 ， 并 显示 
在 页 面 中 。 在 显示 数据 时 ， 需 要 进行 2 次 判断 : 一 次 判断 用 户 的 登记 类 型 〈 上 班 还 是 下 班 ) ， 一 次 判 
断 用 户 的 登记 状态 (人 迟到、 早退 、 正 点 上 、 下 班 》。 关 键 代码 如 下 : 
例 程 14 ”代码 位 置 : 光盘 \TM\03\oa\kqgl\work_note.php 


<?php 
session_start(); // 开 启 session 支 持 
include "../inc/chec.php"; // 包 含 权 限 检 查 文件 
include "../conn/conn.php"; // 包 含 数据 库 链 接 文 件 
include "../inc/func.php"; // 包 含 自 定义 函数 文件 
> 
<link href="../css/style.css" rel="stylesheet" /> /引进 外 部 css 样 式 文件 
<script src=".Jjs/client js.js"></script> /引进 js 脚本 文件 
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oo <a href="#" onclick="javascript:openWin=open('p_login.php?r_id=<?php echoS_ GET[u id]; ?>' ,","width= 
420,height=260,scrollbars=n0");"> 
<?php 
上 请“ 判 断 是 哪 种 功能 类 型 六 
© if($_GET[u id] =— 14){ 
echo "上 下 班 登记 "; 
}else if($_GETI[u id] = 15){ 
echo " 病 事假 登记 "; 
}else if($_GETI[u id] = 10)!{ 
echo "加 班 登 记 "; 
} 
?></a> 
<?php 
人 # ”显示 登记 信息 */ 
$sqlstr = "select id,r_date,r_time,r_type,r_state,r_remark from tb_register where r id=".$ GETIu id]." and p_id = 
".$_SESSIONI[id]; 
$result = mysql_query($sqlstr, $conn); 
while($rows = mysql_fetch_array($result)){ 
> 
<tr> 
<!-- 输出 登记 日 期 --> 
<td height="25" align="center" valign="middle"><?php echo Srows[r_date]; ?></td> 
<!- 输出 登记 时 间 -> 
<td height="25" align="center" valign="middle"><?php echo Srows[r_time]; ?></td> 
<td height="25" align="center" valign="middle"> 
<!-。 输出 登记 类 型 -> 
<2php 
目 Switch(Srows[r_type]){ 
case 0: 
echo "下 班 "; 
break; 
case 1: 
echo "上 班 "; 
break; 
Case 2: 
echo "加 班 签到 "; 
break; 
Case 3: 
echo "加 班 签 退 "; 
break; 
case 4: 
echo "病假 "; 
break; 
Case 5: 
echo "事假 "; 
break; 


“8。 


第 3 章 办公 自动 化 管理 系统 (Apache+PHP+phpMyAdmin+MySQL 5.0 实现 ) 


<td height="25" align="center" valign="middle"> 
< 输出 登记 状态 -> 
<2php 
9 Switch(Srows[r_type]){ 
case 1: 
echo ($rows[r_state] == 0)?" 正 点 上 班 ":" 迟 到 "; 
break; 
case 0: 
echo ($rows[r_state] 一 0)2" 早 退 ":" 正 点 下 班 "; 
break; 
Case 2: 
echo ($rows[r_state] 一 0)2" 正 点 加 班 ":" 晚 点 加 班 "; 
break; 
Case 3: 
echo ($rows[r_state] 一 0)?" 加 班 早退 "加 班 下 班 "; 
break; 
Case 4: 
echo ($rows[r_state] == 0)?" 病 假 ":" 事 假 "; 
break; 


<!- 输出 备注 -> 
<td height="25" align="center" valign="middle"><?php echo (Srowslr_remark] != nul)?S$rows[r_remark]: 
无 ; ?></td> 
</t> 
<?php }7> 


/ 训 突 突 实 迪夫 尖 突 灾 迪 内 内 风光 淆 内 帘 内 风灾 内 突 兴 突 内 风光 帘 闪闪 内 


Ah 代码 贴 二 

@ onclick="…": 这 里 的 js 脚本， 使 用 的 是 第 三 种 方式 ， 在 表单 元 素 或 标签 中 使 用 。 当 单 击 超 链 接 时 ， 将 触发 一 个 
窗口 事件 ， 打 开 一 个 新 的 窗口 。open 函数 的 基本 格式 为 open(url,name,feature)。 其 中 url 为 要 打开 的 地 址 ，name 为 打开 
窗 体 的 名 字 ，features 为 窗 体 属性 特征 ， 如 宽 、 高 等 。 

@ 根据 u id 来 判断 是 哪 种 功能 类 型 ， 也 就 是 参数 u id 的 值 。 分 3 种 情况 : 上 下 班 登记 、 病 事假 登记 和 加 班 登记 。 

四 判断 登记 类 型 ， 一 共 分 6 种 情况 : 上班、 下班、 病假、 事假、 加 班 签到 和 加 班 签 退 。 

@ 判断 状态 类 型 ， 一 共 分 10 种 情况 : 上 班 迟 到 、 上 班 早退 、 正 点 上 班 、 正 点 下 班 、 正 点 加 班 、 加 班 下 班 、 加 班 
晚点 、 加 班 早退 、 病 假 和 事假 。 


当 单 击 “ 上 下 班 登记 ” 超 链接 时 ， 就 会 弹出 登记 页 面 ， 用 户 就 可 以 进行 上 下 班 的 登记 操作 了 ， 在 
登记 类 型 下 拉 列 表 框 中 选择 登记 类 型 ， 如 果 迟 到 或 早退 等 特殊 情况 ， 需 要 在 “备注 ”中 说 明 原 因 ， 最 
后 单 击 “ 登 记 ” 按 钮 进行 登记 ， 如 果 登 记 成 功 ， 将 显示 提示 对 话 框 。 登 记 页 面 的 运行 结果 如 图 3.25 
所 示 。 
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扑 名 : kx 
守 Ew 型 : [于 于 二 
PN 生计 成 


吴 圭 所 以 梧 了 | = 一 
各 注 : 
| 到 


图 3.25 上 下 班 登 记 的 运行 结果 


在 登记 界面 中 ， 主 要 有 3 个 表单 元 素 和 1 个 隐藏 表单 ， 如 表 3.8 所 示 。 


表 3.8 上 下 班 登记 的 表单 元 素 


名 称 | 元 素 类 型 重要 属性 含义 
Pl form method="post" action="p_login_chk.php” 登记 表单 
u name text value="<?php echo $ SESSION[u_name]; ?>" readonly="readonly" 登记 人 
<?php ifS_GETI[r id] = 14){7?> 
<option value="1"> 上 班 </option> 
<option value="0"> 下 班 </option> 
<?php }else ifS_GETIr_id] = 15){7?> 
i a <option value="4"> 病 假 </option> 登记 类 型 


textarea 
hidden 


<option value="5"> 事 假 </option> 
<?php }else ift$_GETIr_id] = 16){7?> 
"> 加 班 签到 </option> 


<option value= 


<option value="3"> 加 班 签 退 </option> 


<?php }2> 
r remark 
rid 


name= 
value="<?php echo $_GETI[r id]; ?>" 


r_remark" rows="5" 


备注 
功能 id 


Submit2 


选择 村 


Submit 


value=" 回 复 " onclick="retum re_back();" 


“登记 ”按钮 


日 应 的 登记 类 型 ， 如 上 班 ， 提 交 表 单 后 ， 系 统 就 会 跳 到 处 理 页 (P_login_chk.php) 处 理 。 在 处 


理 页 中 ， 首 先 判断 是 登记 类 型 上班、 下班) ， 然 后 根据 登记 类 型 取得 相对 应 的 标准 时 间 ， 通 过 两 个 


时 间 的 对 

键 代码 如 下 : 
例 程 15 ”代码 位 置 ， 光盘 \TM\03\oa\kqgl\p_login_chk.php 
<?php 
session_start(); // 开 启 session 支 持 
include "../conn/conn.php"; // 包 含 数据 库 链 接 文件 
include "../inc/chec.php"; // 包 含 权 限 检查 文件 


入 1 代表 迟到 0 代表 正点 登记 */ 
上 # 判断 功能 类 型 ， 如 上 下 班 登 记 、 加 班 登 记 。*/ 


SS 


bE， 得 到 登记 状态 (迟到 、 早 退 、 正 点 上 下 班 》， 最 后 执行 insert 语句 ， 添 加 新 记录 。 程 序 关 
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if(($r id=="14") or (Sr id 一 "16")f 
上 # 判断 登记 类 型 ， 如 上 班 、 下 班 等 */ 
if($u_type— 0) 
S$t_sql= "select * from tb_setup where id = 2"; // 取 得 下 班 标准 时 间 
else if($u type — 1) 
S$t_sql= "select * 位 om tb_setup where id = 1"; // 取 得 上 班 标准 时 间 
else if($u type — 2) 
S$t_sql = "select * from tb_setup where id = 3"; // 取 得 加 班 上 班 时 间 
else if($u_type 一 3) 
S$t_sql = "select * from tb_setup where id = 4"; // 取 得 加 班 下 班 时 间 
/ 深 光 光 实 光 突 灾 灾 灾 央 火灾 炎 家 突 光 内 风 风 突 央 突 实 光源 淆 风灾 风 央 灾 光 灾 光 容光 风灾 实 容 交 突 内 实 容 实 灾 内 实 容 突 灾 灾 风 灾 灾 灾 灾 实 光 / 
$t rst= mysql query($t sql,$conn); 
$t rows = mysql_fetch_row(S$t_rst); 


$s_time = $t_rows[2]; // 规 定 的 标准 时 间 
9 Snow_time = date("H:i:s"); // 当 前 的 登记 时 间 
[2 $1 sql= "insert into tb register (r date,r time,r type,r state,r remark,r id,p id) 
values(".date("Y-m-d").",".date("H:i:s").",".$ POST[u typel].",".((strtotime(Snow_time) - strtotime($s_time) > 
0)21:0)."".$ POST[r remark].",".$ POST[r id].",".$ SESSION[id].")"; 


}else if($r id =—= "15") 
$1 sql= "insert into tb register (r date,r time,r type,r state,r remark,r id,p id) 
values(".date("Y-m-d").",".date("H:i:s").",".$_POST[u_type].",",".$_ POST[r_remark].",".$_POST[r id].",".$_SESSION[id]." 
)"; 
$1 rst = mysql query($] sql,$conn); 
必 “登记 完成 后 ， 关 闭 窗口 。 */ 
if($1_rst) 
echo "<script>alert(' 登 记 完成 ');window.close(;</script>"; 
else 
echo "<script>alert( 错 误 ');history.go(-1);</script>"; 


/ 半 当 六 这 率 六 率 闪 弟弟 素 康 率 素 率 素 六 率 闵 率 / 


人 


Ah 代码 贴 二 

@ date(0) 时 间 函 数 可 以 通过 不 同 的 组 合 返 回 不 同 的 时 间 样式 。 如 程序 中 的 date("H:i:s")， 还 可 以 加 上 年 、 月 、 日 、 星 
期 等 等 ， 如 date("Y-m-d H:i:s 1"). 

@ ((strtotime($now_time) - strtotime($s_time) > 0)21:0): 根据 以 上 内 容 得 到 的 SQL 语句 ， 其 中 strtotime 函数 是 PHP 
的 一 个 时 间 函 数 ， 作 用 是 将 一 个 日 期 时 间 描 述 解析 为 一 个 unix 时 间 戳 ， 如 strtotime("2007-07-11 13:49:29") 输出 的 结果 
就 是 1184132969， 这 时 对 两 个 时 间 进行 计 算 ， 就 可 以 得 到 时 间 的 大 小 关系 了 。 


3.8.4 设置 时 间 的 实现 过 程 


国 ”考勤 管理 使 用 的 数据 表 : tb_register、tb_setup 
考勤 记录 页 面 的 功能 主要 有 两 部 分 ， 一 是 显示 所 有 员工 的 考勤 信息 ， 二 是 设置 标准 时 间 。 显 示 所 
有 员工 的 考勤 信息 的 实现 过 程 和 3.8.3 节 中 的 实现 方式 相 类 似 ， 唯 一 不 同 的 就 是 包括 了 全 体 职 员 ， 只 要 
略微 改动 SQL 语句 即 可 。 
下 面 主要 来 看 一 下 设置 标准 时 间 页 面 。 在 “考勤 记录 ”页 面 中 单 击 “ 设 置 时 间 ” 超 链接 ， 进 入 设 
置 时间 页 面 ， 设 置 时 间 页 面 的 运行 结果 如 图 3.26 所 示 。 
“171。 乡 
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上 班 签到 下 班 签 退 加 班 签到 | 加 三 签 退 
08: 20:00 17:10:00 17:30:00 Pa:oo:m 
汪 | 和 | | 六 | 
图 3.26 设置 时 间 页 面 的 运行 结果 
在 本 页 面 中 ， 从 tb_setup 表 中 读 取 预 定义 的 标准 时 间 ， 有 4 个 标准 时 间 ， 分 别 是 “上 班 签到 ”、 
“下 班 签 退 ”、“ 加 班 签到 ”和 “加 班 签 退 ”。 程 序 关 键 代码 如 下 : 
例 程 16 ”代码 位 置 ， 光盘 \TM\03\oa\kqgl\set.time.php 


<2php 
session_start(); // 开 启 session 支 持 
include "../inc/chec.php"; /包含 权限 检测 文件 
include "../conn/conn.php"; /包含 数据 库 链接 文件 
7> 
<link href="../css/style.css" rel="stylesheet" /> // 引 入 css 外 部 链接 文件 
<script sre="../js/client_js.js"></script> // 引 入 js 脚本 文件 


<form name="form1" method="post" action="set time chk.php"> 
<table border="1" cellspacing="0" cellpadding="0" background="../images/bg.jpg"> 
<tr> 
<td width="150" height="25" align="center" valign="middle"> 上 班 答 到 </td> 
<td width="150" height="25" align="center" valign="middle"> 下 班 签 退 </td> 
<td width="150" height="25" align="center" valign="middle"> 加 班 签到 </td> 
<td width="150" height="25" align="center" valign="middle"> 加 班 签 退 </td> 


</tr> 
<?php 
$sqlstr = "select * from tb_setup"; // 提 取 表 中 的 标准 时 间 
$result = mysql_query($sqlstr,$conn); // 返 回 结果 集 
Snum = 0; /设置 序号 
> 
<tr> 


<?php while($rows = mysql fetch row($result)){ ?> 
<td height="30" align="center" valign="middle"> 


0 <input type="text" name="] time<?php echo Snum;?>" value="<?php echo $rows[2]; ?>" size=15></td> 
<?php Snum++;}?> 
</tr> <tr> 
[2 <td height="30" align="center" valign="middle"><input type="submit" name="u_logo" value=" 设 置 "></td> 


<td height="30" align="center" valign="middle"><input type="submit" name="d_logo" value=" 设 置 "></td> 
<td height="30" align="center" valign="middle"><input type="submit" name="a_logo" value=" 设 置 "></td> 
<td height="30" align="center" valign="middle"><input type="submit" name="q_logo" value=" 设 置 "></td> 
</t> 
</table> 
</form> 


< 代码 贴 十 
@ 变量 Snum 是 为 了 在 while 循环 语句 中 输出 不 同 的 表单 元 素 的 名 称 ， 每 次 循环 Snum 自 加 1。 
@ 生成 4 个 设置 时 间 的 按钮 ， 在 处 理 页 中 ， 根 据 不 同 的 名 字 做 不 同 的 处 理 。 


当 调 整 了 其 中 的 一 项 后 ， 单 击 “设置 ”按钮 ， 就 进入 到 处 理 页 ， 在 处 理 页 中 ， 会 根据 按钮 的 名 称 


SS 
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和 “text” 元 素 的 value 值 来 进行 相关 的 操作 。 程 序 关键 代码 如 下 : 
例 程 17 ”代码 位 置 ， 光盘 \TM\03\oa\kqgl\set.time_chk.php 


<?php 
session_start(); /开启 session 设 置 
include "../inc/chec.php"; // 包 含 权限 检查 文件 
include "../conn/conn.php"; // 包 含 数据 库 链 接 文 件 


片 根据 名 称 判断 事件 是 哪个 按钮 产生 的 ， 并 生成 不 同 的 SQL 语 句 */ 
ifisset($_ POST[u logo])){ 


$sqlstr = "update tb_setup set | time =".$_POSTI[L_time0]. "where id = 1"; /设置 上 班 时 间 
jelseiflisset($_ POST[d logo])){ 

$sqlstr = "update tb_setup set | time =".$_POST[Ltimel]. "where id = 2"; /设置 下 班 时 间 
}elseifisset($ POST[a logo]))f 

$sqlstr = "update tb_setup set | time =".$_POST[Ltime2]. " where id = 3"; /设置 加 班 上 班 时 间 


}else iffisset($_ POST[q logo])){ 
$sqlstr = "update tb_setup set | time ='".$_POSTI[L time3]. " where id = 4"; /设置 加 班 下班 时 间 
} 


else 
echo "<script>alert(' 非 法 登录 ');window.close(;</script>"; 


/ 检 永 可 半球 来 束 束 素来 于 束 束 束 束 可 末 可 束 束 刺 训 束 束 永 本 训 束 束 训 本 训 可 本 字 可 于 束 本事 可 率 可 束 束 素 本 束 可 来 束 人 


$result = mysql query($sqlstr,$conn); 
if($result) 

echo "<script>alert(' 设 置 成 功 ");window.close0;</script>"; 
else 

echo "<script>alert(' 设 置 失 败 ');window.close();</script>"; 


3.9 后台 首页 设计 


由 于 后 台 管理 主要 是 针对 管理 员 开 放 的 ， 普 通用 户 无 法 访问 到 这 里 ， 所 以 在 页 面 风 格 的 设计 上 相对 
要 简单 得 多 。 不 需要 艳丽 的 图 片 、 极 炫 的 特效 ， 只 要 干净 、 整 洁 ， 给 人 一 种 朴实 无 华 的 感觉 是 最 好 的 。 


3.9.1 后 台 首 页 概述 


如 果 说 前 台 是 系统 的 外 衣 ， 那 么 后 台 就 是 系统 的 灵魂 了 。 数 据 更 新 、 系 统 升级 ， 甚 至 是 安全 隐患 ， 
都 源 于 后 台 的 设计 是 否 完善 ， 功 能 是 否 强大 。 可 以 说 ， 后 台 越 完美 ， 系 统 拥 有 的 外 衣 才 会 越 华丽 ， 人 
们 的 目光 才 会 被 吸引 。 

办 公 自 动 化 管理 系统 的 后 台 首页 主要 包括 的 功能 如 下 : 

网 站 首部 导航 栏 : 包括 当前 时 间 、 首 页 、 重 新 登录 和 退出 登录 。 

网 站 左 侧 导航 栏 : 包括 各 个 管理 模块 及 分 类 。 

部 门 管理 模块 : 主要 用 于 对 部 门 信息 的 操作 ， 包 括 添 加 、 修 改 、 删 除 和 查看 功能 。 
职员 管理 模块 : 主要 用 于 对 职员 信息 的 统一 管理 ， 包 括 添加 、 修 改 、 删 除 和 查找 职员 。 
权限 管理 模块 : 主要 用 于 对 部 门 、 职 员 和 用 户 组 的 功能 权限 分 配 。 

系统 管理 模块 : 维护 系统 日 志 、 修 改 管理 员 密码 和 系统 数据 的 备份 。 


办 办 办 多 


“7. 
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下 面 看 一 下 本 案例 中 提供 的 后 台 首 页 , 该 首页 在 本 书 光 盘 中 的 路 径 为 \TM\03\admin\admin_main.php， 
如 图 3.27 所 示 。 


系统 首页 | 重新 登录 | 退出 


0431-12345678 修改 /删除 


0431-12345678 小 必 /删除 


修改 /出 除 


修改 / 册 除 


修改 /删除 


图 3.27 办 公 自动 化 管理 系统 后 台 首 页 
3.9.2 ”后台 首页 技术 分 析 


后 台 页 面 和 前 台 页 面 的 布局 是 相似 的 ， 都 是 采用 “上 方 固定 ， 左 侧 嵌 套 ” 的 框架 结构 。 在 上 方 框 
架 (topFrame) 显示 banner 和 首部 导航 ， 在 左 侧 框架 (leftFrame〉 中 显示 功能 列表 。 中 间 的 显示 区 
CmanFrame) 显示 各 级 窗 体 。 


3.9.3 ”后 台 首页 的 实现 过 程 


国 后台 首页 使 用 的 数据 表 : tb_controller 

下 面 来 看 一 下 后 台 页 面 中 框架 布局 的 应 用 ， 程 序 代 码 如 下 : 
例 程 18 ”代码 位 置 ， 光盘 \TM\03\oa\admin\admin_main.php 

<!-- 定 义 顶 部 框架 和 框架 内 显示 的 内 容 --> 


<frameset rows="88,*" cols="*" frameborder="no" border="1" framespacing="0"> 
<frame sre="top.php" name="topFrame" scrolling="No" noresize="noresize" id="topFrame" title="topFrame" /> 
<!-- 定 义 嵌 套 的 左 侧 框 架 和 框架 内 显示 的 内 容 --> 
<frameset rows="*" cols="216,*" framespacing="0" frameborder="no" border="1"> 
<frame sre="left.php" name="leftFrame" scrolling="No" noresize="noresize" id="leftFrame" title="leftFrame" /> 


二 -定义 主 框架 内 容 -> 
\ 。174 。 
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<frame src="main.php" name="mainFrame" id="mainFrame" title="mainFrame" /> 
</frameset> 
</frameset> 
<!-- 当 浏览 器 不 支持 框架 时 所 显示 的 内 容 --> 
<noframes><body> 
</body> 
</noframes></html> 


3.10 ”部 门 管理 模块 设计 


一 个 成 熟 、 稳 定 的 企业 一 定 要 有 一 个 合理 的 部 门 结构 ， 包 括 每 个 部 门 需要 做 什么 工作 、 部 门 之 间 
的 协调 关系 和 部 门 之 间 的 上 下 级 关系 等 ， 都 要 明确 下 来 ， 这 样 才能 各 尽 其 职 ， 不 会 出 现 资源 浪费 ， 提 
高 企业 整体 的 效率 。 


3.10.1 部 门 管理 模块 概述 


部 门 管理 模块 包括 两 大 部 分 : 

1. 查看 部 门 

查看 各 个 部 门 名 称 和 部 门 之 间 的 上 下 级 关系 ， 还 可 以 对 部 门 的 信息 和 级 别 进行 修改 ， 如 果 是 最 底 
层 的 部 门 ， 则 可 以 对 其 进行 删除 操作 。 

2. 添加 部 门 

可 以 添加 新 的 部 门 ， 包 括 部 门 名 称 、 上 级 部 门 和 部 门 备注 。 

部 门 管理 框架 如 图 3.28 所 示 。 


v 
添加 部 门 


一 一 一 一 一 ?| | 查看 部 站 


En 


| 修改 部 门 [开除 部 站 I [长 加 部 门 ] 
除 失败 


修改 失败 出 
修改 部 站 > 
删除 成 功 


图 3.28 ”部门 管理 操作 流程 图 
.175。 g 
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3.10.2 部 门 管理 模块 技术 分 析 


部 门 管理 中 的 技术 难点 是 : 如 何 实现 查看 部 门 模块 中 的 动态 显示 部 门 结构 的 功能 。 这 里 用 
javascript+ 递 归 函 数 来 实现 。 下 面 来 详细 讲解 。 

当 用 户 单 击 “ 查 看 部 门 ” 时 ， 系 统 开始 查找 tb_depart 数据 库 。 首 先 找到 根部 门 的 信息 列表 ， 并 判 
断 第 一 个 根部 门 是 否 有 下 级 部 门 。 如 果 没 有 ， 则 直接 输出 部 门 名 称 、 修 改 和 删除 操作 ， 然 后 查找 下 一 
个 根部 门 ， 如 果 有 下 级 部 门 ， 则 调用 自 定义 函数 list_menu($num,$wid,&$m)。 其 中 : 

加 ”$num: 为 上 级 部 门 id 号 。 

$wid: 为 表格 宽度 。 

回 $m: 为 表单 元 素 id 变量 值 。 

在 这 个 函数 中 ， 执 行 步骤 如 下 : 

(1) 查找 上 级 部 门 为 Snum 的 部 门 列 表 。 

(2) 判断 第 一 个 部 门 是 否 有 下 级 部 门 。 

(3) 如 果 没 有 ， 则 输出 部 门 名 称 、 修 改 和 删除 操作 ， 然 后 查找 下 一 个 同 级 部 门 。 

(4) 如 果 有 下 级 部 门 ， 则 再 次 调用 list_menu($num,$wid,&$m) 函 数 。 

(5) 重复 步骤 (1) 一 步骤 (4) 。 

这 时 ， 相 信 读 者 已 经 看 出 : list_menu(0) 正 是 一 个 递归 函数 。 递 归 函 数 就 是 在 当 满足 一 定 的 条 件 时 ， 
函数 自己 调用 自己 ， 经 过 层 层 调用 ， 最 终 达 到 解决 问题 的 目的 。list_menu() 函 数 的 代码 如 下 

例 程 19 ”代码 位 置 ， 光 盘 \TM\03\oa\admin\inc\func.php 


<?php 

function list_menu($num,$wid,&$m){ 
上 #。 连接 数据 库 */ 
$conn = mysql_connect("localhost","root","root"); 
mysql_select_db("db_office", $conn); 
mysql_query("set names gb2312"); 
/ 认 让 素 于 玉 素来 于 于 素来 于 于 玉 素 
入 ”查询 同 级 部 门 */ 
$sqlstr = "select * from tb depart where up depart= ".Snum; 
$result = mysql query($sqlstr,Sconn); 
/中环 下 来 于 站 冰 半球 于 站 玉 间 虽 玉 音素 素 间 人 

> 
<!-- 隐藏 域 -> 

<tr id="OpenMe<?php echo $m; ?>" style="display:none;"> 

<td> <table width="<?php echo $wid; ?>%" border="0" cellspacing="0" cellpadding="0"> 
<tr> 
<td height="25" align="center"><table width="<?php echo ($wid -3); ?>%" border="0" cellspacing="0" 
cellpadding="0"> 
<?php 
族 ”循环 输出 同 级 部 门 。 */ 
while($rows = mysql fetch row(S$result)){ 
证 ”查看 下 属 部 门 。 */ 
$sqlstrl = "select * from tb depart where up depart=".$rows[0]; 
Sresultl = mysql query($sqlstrl,$conn); 


S$nu = mysql_num rows(S$result]); 
S “176。 
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上 ”如果 当前 部 门 没有 下 属 部 门 时 */ 
这 !$nu){ 
$m += 1 
> 
© <tronMouseOver="this.style.background='#96F7F4'" on MouseOut="this.style.background=""> 
<td width="100%" align="left">&nbsp;&nbsp;&nbsp; <img src="../images/folder.gif" width="16" 


height="16" border="0"><?php echo $rows[1] ?>----—------—---<a href="edit_depart.php?id=<?php echo $rows[0]; ?>"> 修 改 
</a>||<a href="del_depart_chk.php?id=<?php echo $rows[0]; ?>" onClick="retum cfm();"> 删 除 </a></td></tr> 
<?php 
上 # ”当前 部 门 有 下 属 部 门 时 */ 
elsef 
$m+= 1; 
?> 


<!- “鼠标 划 过 样式 -> 
<tr onMouseOver="this. style.background=#96F7F4" onMouseOut="this.stylebackground="> 
@ <td>&nbsp;<a href="Javascript:ShowMe(img<?php echo $m; ?>,Open Me<?php echo Sm; ?>)"><img 
sre="../Images/jia.gif" border="0" alt=" 展 开 " id="img<?php echo Sm; ?>"><?php echo 
S$rows[1];?></a>-- 一 -一 -一 一 一 一 <a href="edit_depart.php?id=<?php echo $rows[0]; ?>"> 修 改 </a>|| 删 除 </td></tr> 
<?php 
目 list_ menu(Srows[0],Swid,Sm); 


全 
?> 


</table></td></tr></table></td></tr> 
<?php}?> 


Ah 代码 由 二 

@ onMouseOver…onMouseOut: onMouseOver 表示 饼 标 指针 停留 在 当前 元 素 上 时 的 状态 ，onMouseOnut 事件 表示 鼠 
标 指针 离开 当前 元 素 时 的 状态 。 本 行 用 不 同 的 颜色 表示 两 种 不 同 的 事件 。 

@ 当前 部 门 有 下 属 部 门 时 ， 单 击 图 片 或 文字 链接 ， 触 发 一 个 js 事件 ， 显 示 隐 藏 域 。 

上 @ 调用 自身 函数 。 


在 这 个 模块 中 , 同时 使 用 了 另 一 个 自 定义 函数 isbool($id,$dname), 该 函数 将 $dname 参数 和 tb_depart 
表 中 的 部 门 名 称 一 一 比较 ， 如 果 重 复 ， 则 返回 tue， 和 否则 返回 false。S$id 是 在 修改 部 门 时 ， 先 去 掉 要 修 
改 的 部 门 的 名 称 再 进行 比较 。 在 信息 处 理 页 中 ,根据 返回 的 值 进行 操作 。isbool0 函 数 的 程序 代码 如 下 : 
例 程 20 ”代码 位 置 : 光盘 \TM\03\oa\admin\inc\func.php 
function isbool($id,$dname)! 
/* ”连接 数据 库 */ 
$conn = mysql_connect("localhost","root","root"); 
mysql select db("db office",$conn); 
mysql_ query("set names gb2312"); 


/容光 灾 裕 兴 实 突 光 内 突 灾 内 光 实 内 交 风 安 / 


$sqlstr = "select * from tb_depart where id != $id d_name = '$dname'"; // 创 建 查询 SQL 语 句 


$result = mysql_query($sqlstr, $conn); // 执 行 SQL 语 句 
if(mysql_num _rows($result)>0) // 判 断 是 否 有 记录 集 
Sisbool = true; // 如 果 有 ，S$isbool = true 
else 
Sisbool = false; /否则 $isbool= false 
Tetum $isbool; /返回 Sisbool 


| 
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3.10.3 部门 查 看 的 实现 过 程 

国 部门 查看 模块 使 用 的 数据 表 : tb_depart 

通过 选择 导航 栏 中 的 “部 门 管理 ”/“ 查 看 部 门 ”， 进 入 部 门 查看 页 面 。 在 部 门 查看 页 面 中 显示 部 
门 设置 及 架构 情况 ， 部 门 查 看 页 面 的 运行 结果 如 图 3.29 所 示 。 


办 公有 自动 化 _ 系统 首页 | 重新 登录 | 退出 


日 查看 部 门 


图 3.29 ”部门 查看 页 面 的 运行 结果 
在 部 门 查看 页 面 中 ， 使 用 到 了 递归 函数 。 首 先 查找 根部 门 〈 根 部 门 的 条 件 是 top_depart = 0) ， 并 
返回 根部 门 的 结果 集 ; 接着 使 用 while 循环 输出 所 有 根部 门 ， 每 输出 一 个 根部 门 时 ， 都 要 查看 当前 部 门 
是 否 有 子 部 门 (下属 部 门 》。 如 果 没 有 子 部 门 , 那么 直接 输出 部 门 名 称 和 对 部 门 的 操作 (修改 和 删除 》; 
如 果 根 部 门 有 子 部 门 ， 则 调用 递归 函数 〈list_ menu0) 。 该 页 面 的 程序 代码 如 下 : 
例 程 21 ”代码 位 置 ， 光盘 \TM\03\oa\admin\bmgl\show_depart.php 


<?php 
session_start(); // 开 启 session 
include "../inc/chec.php"; // 包 含 权 限 检 查 文件 
include "../conn/conn.php"; // 包 含 数据 库 链 接 文 件 
include "../inc/func.php"; // 包 含 自 定义 函数 文件 
> 
‘<script sre="../js/admin_js:js"></script> /1/ 引 入 js 脚本 文件 
<link href="../css/style.css" rel="stylesheet"> /引入 外 部 css 样 式 
<body onLoad="ShowMelimgl,OpenMel)"> //onLoad 事 件 ， 表 示 当 页 面 被 载 入 时 就 调用 ShowMe() 方 法 


<!-- 查 看 部 门 信息 --> 
<table width="100%" height="25" border="0" cellpadding="0" cellspacing="0"> 


<?php 
必 ”找到 根部 门 */ 
$sqlstr = "select * from tb depart where top depart = 0"; 
$result = mysql query($sqlstr,$conn); 
上 ”隐藏 域 id 号 */ 
$m= 1; 
必 ”循环 输出 所 有 根部 门 */ 
while($rows = mysql_fetch_ row(Sresulb)f 


Sn 
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Swid = 100; 
上 ”查看 下 属 部 门 。 */ 
$sqlstrl = "select * from tb depart where up depart=".$rows[0]; 
$resultl = mysql query($sqlstrl,$conn); 
$nu = mysql_num rows(S$result1); 
片 ”如 果 当 前 部 门 没有 下 属 部 门 时 */ 
if(!Snu){ 
> 
<tr onMouseOver= "this.style.background=:#96F7F4" on MouseOut="this.style.background=""> 
<td>&nbsp;&nbsp;é&nbsp;&nbsp;<a href="<?php echo SPHP SELF; ?>"><img src="../Images/folder.gif" 
border="0" alt=" 展 开 " id="img<?php echo $m; ?>"><?php echo $rows[1]; ?></a>: <a 
href="edit_depart.php?id=<?php echo $rows[0]; ?>"> 修 改 </a>||<a href="del_depart_chk.php? 
onClick="retum cfm(); 必 删除 </a></td> 
</t> 
<?php 
族 ”如果 当前 部 门 有 下 属 部 门 时 。 */ 


jelsef 


> 
<tr onMouseOver="this.style.background='#96F7F4" onMouseOut="this.style.background=""> 
<td><a href="Javascript:ShowMe(img<?php echo $m; ?>,Open Me<?php echo $m; ?>)"><img 


src="../Images/jia.gif" border="0" alt=" 展 开 " id="img<?php echo $m; ?>"><?php echo $rows[1]; ?></a>--- 一 ------ 一 -一 <a 
href="edit_depart.php?id=<?php echo $rows[0]; ?>"> 修 改 </a>|| 删 除 </td> 
</tr> 
<?php 


作 ”输出 同 级 部 门 ， 调 用 递归 函数 */ 


list menu($rows[0],$wid,$m); 


$m+= 1; 

} 

必 循环 结束 */ 
?> 
1. 修改 部 门 


在 查看 部 门 页 面 中 ， 可 以 对 部 门 的 名 称 、 上 级 部 门 及 主要 职责 等 相关 信息 进行 修改 。 单 击 要 修改 
的 部 门 名称 后 面 的 “修改 ” 超 链 接 进入 修改 部 门 页 面 。 修 改 页 面 的 运行 结果 如 图 3.30 所 示 。 


办 公 自 动 化 ee 系统 至 页 | 重新 登录 | 退出 
部 门 名 称 : | 芭 计 部 ”| | 

人 Ne ee = 
| te 名: 殉 。 习 | 
日。 账 叶 权 限 [区 开 前 各 页 面 ， 忆 所 美工 、 photoshop、 Flash 本 

口 用户 组 设置 备注 : 
| 9 权限 分 本 加 
te | 
| 区 系统 日 志 Es | 
日 数据 备份 

0 修改 于 码 


图 3.30 ”修改 部 门 页 面 的 运行 结果 


“mg 
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修改 部 门 页 面 (edit_depart.php〉 中 的 主要 表单 元 素 如 表 3.9 所 示 。 
表 3.9 修改 部 门 页 面 中 的 表单 元 素 


名 称 | 元 素 类 型 重要 属性 含义 
d_name Text Size="20" value="<?php echo Srows[d_name] ?> 部 门 名 称 
<?php 


while($tmprows = mysql_fetch_array($tmpresult)){ 
if($tmprows[id] 一 $rows[top_depart]){ 
echo "<option value=".$tmprows[id]." 
u id select selected>".$tmprows[d_name]."</option>"; 列 出 所 有 部 门 
}else 
echo "<option value=".$tmprows[id].">".$tmprows[d_name]." 


</option>"; 

}7> 
remark textarea ?php echo $rows[remark] ?> 备注 信息 
id hidden value="<?php echo $rows[id] ?>" 修改 部 门 的 id 
Submit Submit name="Submit" value=" 修 改 " onclick="return a_check();" “修改 ”按钮 


当 管理 员 修 改 完 相 应 的 信息 后 单 击 “ 修 改 ” 按 钮 提交 修改 信息 ， 系 统 转 到 处 理 页 
Cedit_depart_chk.php) ， 首 先 判断 输入 的 部 门 名 称 是 否 重复 。 如 果 重 复 ， 则 返回 ， 如 果 不 重复 ， 则 继 
续 执 行 ， 确 定 修 改 后 的 上 级 部 门 和 根部 门 。 关 键 代 码 如 下 : 

例 程 22 ”代码 位 置 ， 光盘 \TM\03\oa\admin\bmgl\edit_depart_chk.php 


<? 
session_start(); // 开 启 session 
include "../inc/chec.php"; // 包 含 权 限 检查 文件 
include "../conn/conn.php"; // 包 含 数据 库 链 接 文件 
include "../inc/func.php"; // 包 含 数据 库 链接 文件 


必 ”判断 输入 部 门 名 称 是 否 重复 。 */ 
iffisbool($_POST[id]$_POST[d_name])){ 
echo "<script>alert(' 名 称 已 存在 ， 请 重新 输入 !!);history.go(-1);</script>"; 
exit(); 
’ 
全。 修改 部 门 ， 确 定 上 级 部 门 和 根部 门 */ 
if($ POST[u id] != 0){ 
族 ”查找 上 级 部 门 的 根部 门 。 */ 
$sqlstr = "select top depart from tb depart where id=".$ POST[u id]; 
$result = mysql_query($sqlstr,$conn); 
$rows = mysql fetch array($result); 
证 ”如 果 存在 上 级 部 门 ， 就 取得 上 级 部 门 的 根部 门 。*/ 
if ($rows[top_depart] != 0) 
S$top depart = $rows[top depart]; 
证 ”如 果 不 存在 ， 将 上 级 部 门 作为 根部 门 ”*/ 
else 
S$top depart =$ POST[u id]; 
}else 


So. 
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卢 如 果 没 有 上 级 部 门 ， 那 么 就 将 自身 定 为 根部 门 */ 
S$top depart = 0; 
店 创建、 执行 修改 部 门 的 SQL 语 名。 */ 
S$sqlstr = "update tb depart set d name=".$ POST[d namel.",top depart=".$top depart.", up depart= 
".$ POSTIu id].", remark =".$ POST[remark]." whereid=".$ POST[id]; 
$result = mysql query($sqlstr,Sconn); 
re_message(S$result,"show_depart.php"); 
?> 


2. 删除 部 门 

如 果 要 取消 某 个 部 门 ， 可 以 将 该 部 门 删除 。 在 删除 部 门 时 ， 只 能 对 最 底层 的 部 门 进行 删除 ， 如 果 
部 门下 面 有 子 部 门 ， 其 部 门 后 面 的 “删除 ” 超 链接 不 可 用 。 删 除 功能 的 实现 相对 比较 简单 一 点 ， 单 击 
“删除 ” 超 链接 后 ， 系 统 提示 “是 否 确认 删除 部 门 ”， 如 果 单 击 “确认 ” 按 钮 ， 系 统 将 转 到 处 理 页 
(del_depart_chk.php) 进行 删除 处 理 。 程 序 代码 如 下 : 

例 程 23 ”代码 位 置 ， 光盘 \TM\03\oa\admin\bmgl\del_depart_chk.php 


<?php 

session_start(); // 开 启 session 

include "../inc/chec.php"; /包含 权限 查看 文件 
include "../conn/conn.php"; /包含 数据 库 链 接 文件 
include ".inc/func.php"; /包含 自 定义 文件 
$sqlstr = "delete from tb_depart where id =".$_GET[id]; /删除 SQL 语句 

$result = mysql_query($sqlstr,$conn); // 执 行 SQL 语 句 
re_message($result,"show_depart.php"); // 返 回 最 后 结果 

> 


3.10.4 部 门 添加 的 实现 过 程 


用 户 单 击 导航 栏 中 的 “部 门 管理 ”/“ 添 加 部 门 ”， 可 以 进入 添加 部 门 页 面 (add_departphp) ， 该 
页 面 用 于 设置 新 添加 部 门 的 相关 信息 ， 包 括 部 门 名 称 、 上 级 部 门 和 备注 。 添 加 部 门 页 面 的 运行 结果 如 
图 3.31 所 示 。 


办 公 自 动 化 系统 首页 | 重新 登录 | 退出 


部 门 名 称 : | 人 事 部 
上 级 部 门 : | 无 轩 


3.31 添加 部 门 页 面 的 运行 结果 
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添加 部 门 页 面 (add_depart) 主要 包含 一 个 添加 部 门 表单 ， 表单 元 素 的 名 称 、 说 明 及 属性 值 如 表 3.10 
所 示 。 


表 3.10 添加 部 门 页 面 的 表单 元 素 


名 称 | 元 素 类 型 重要 属性 含义 
d name Text name="d_ name" id="d_ name" size="20" | 部 门 名 称 
<?php 

while($rows = mysql_fetch_row($result1)) 


u id select 列 出 所 有 部 门 
echo "<option value=". $rows[0].">".$rows[1]."</option>"; 
ss 
remark textarea name="remark" cols="40" rows="5 "remark" 备注 信息 
Submit submit name="Submit" value=" 添 加 " onclick="return a_checkO:" “添加 ”按钮 


当 管 理 员 提交 表单 后 ， 进 入 处 理 页 (add_depart_chk.php) ， 进 行 添加 操作 。 在 处 理 页 中 ， 首 先 判 
断 输入 的 部 门 名 称 是 否 重复 ， 如 果 名 称 符合 要 求 ， 则 进一步 确定 上 级 部 门 和 根部 门 ， 最 后 执行 insert 
语句 进行 添加 操作 。 处 理 页 的 代码 如 下 : 

例 程 24 ”代码 位 置 ， 光 盘 VTM\WO3\oavadmin\bmglvadd_depart_chk.php 


<? 
session_start(); // 开 启 session 
include "../inc/chec.php"; // 包 含 权限 检查 文件 
include "../conn/conn.php"; // 包 含 数据 库 链 接 文件 
include "../inc/func.php"; // 包 含 自 定义 函数 文件 


证 ”判断 输入 部 门 名 称 是 否 重复 */ 
ifisbool($_ POST[d_name])){ 
echo "<script>alert(' 名 称 已 存在 ， 请 重新 输入 !!");history.go(-1);</script>"; 


exit(); 


} 
族 确定 上 级 部 门 和 根部 门 */ 
if($ POST[u id] {= "0"){ 
$sqlstr = "select top depart from tb depart where id = ".$ POST[u id]; 
$result = mysql_query($sqlstr,$conn); 
$rows = mysql_fetch_row($result); 
if ($rows[top depart] != 0) 
S$top depart = $rows[top depart]; 
else 
S$top_depart = $_POST[u_id]; 
} 
else 
S$top_depart = 0; 
上 添加 新 部 门 */ 
$sqlstr = "insert into tb_depart 
values(",".$ POST[d_name].",".$top_depart.",".$_POST[u id].",".$_POST[remark].")"; 
$result = mysql query($sqlstr,$conn); 
上 输出 添加 结果 */ 
Te_message($resulb"show depart.php") 
?> 


Se 
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3.10.5 ”单元 测试 


本 模块 使 用 了 JavaScript 和 自 定义 函数 来 显示 部 门 结构 列表 , 在 进行 测试 时 发 现 ， 当 部 门 被 删除 到 
只 有 一 个 根部 门 时 ， 就 会 弹出 错误 提示 窗口 ， 如 图 3.32 所 示 。 


AN 当前 页 的 脚本 发 生 滞 误 。 


8 

字符 : 1 

错误 “0Dpenllel ”未 定义 
0 


代码 : 
URL: http://localhost/oafadmin/bmgl/show_depart. php 
是 否 继续 在 该 页 面 上 运行 脚本 程序 ? 
wD 
图 3.32 出 错 信息 


单 击 “是 ”按钮 ， 其 他 操作 一 切 正常 。 经 检查 发 现 ， 在 当前 页 面 被 载 入 时 调用 了 js 脚本 ， 语 句 
如 下 : 

<body onLoad="ShowMe(imgl,OpenMe1)"> 

在 部 门 被 删 到 只 有 一 个 时 ， 变 量 OpenMel 就 不 再 存在 ， 调 用 函数 ShowMe() 时 就 会 报错 ， 将 
onLoad="ShowMe(img1,OpenMe1)" 删 掉 ， 错 误 不 再 出 现 。 


3.11 系统 管理 模块 设计 


系统 管理 模块 在 后 台 系 统 中 占据 着 非常 重要 的 位 置 , 后 台 其 他 的 模块 都 是 针对 前 台 功 能 而 设计 的 。 
而 系统 管理 是 针对 系统 本 身 的 一 些 信 息 、 情 况 而 设计 的 ， 一 般 包括 数据 备份 、 管 理 员 信 息 修改 等 ， 甚 
至 可 以 对 操作 系统 的 配置 文件 进行 操作 ， 可 以 说 是 管理 员 的 管理 员 ， 是 后 台 系 统 中 必 不 可 少 的 组 成 
部 分 。 


3.11.1 系统 管理 模块 概述 


系统 管理 模块 包括 的 功能 有 : 
系统 日 志 : 记录 了 前 、 后 台 用 户 登 录 时 的 相关 信息 。 
回 数据 备份 : 可 以 对 整个 数据 库 进行 备份 、 恢 复 和 删除 。 


1. 
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系统 管理 框架 如 图 3.33 所 示 。 


图 3.33 系统 管理 用 例 图 
3.11.2 系统 管理 模块 技术 分 析 


在 系统 管理 模块 中 ， 保 存 数 据 的 方式 使 用 了 数据 库 和 文件 ， 关 于 数据 库 技术 已 经 介绍 很 多 了 ， 本 
节 主要 讲解 一 下 文件 及 文件 夹 的 相关 操作 。 

对 文件 的 操作 主要 分 3 步 : 打开 文件 ; 读 取 / 写 入 文件 ， 关闭 文件 。 

1. 打开 文件 

打开 文件 使 用 的 是 fopen() 函 数 ， 函 数 的 一 般 格式 如 下 : 

int fopen (string filename,string mode ); 

参数 filename 是 要 打开 的 包含 路 径 的 文件 名 ， 可 以 是 相对 路 径 或 绝对 路 径 。 如 果 没 有 任何 前 级 ， 
则 表示 打开 的 是 本 地 文件 ; 参数 mode 是 打开 文件 的 方式 ， 常 用 的 有 a (追加 ) 、w (只 写 ) 和 (只 读 ) 。 
代码 如 下 : 

$f_open = fopen("../bak/remark.sql","a+"); 

2. 读 取 / 写 入 文件 


fpassthru0) 函 数 ) 。 

fgets() 函 数 的 一 般 格 式 为 : 

string fgets ( int filename [ ,int length ]) ; 

参数 filename 是 被 打开 的 文件 ， 参 数 length 是 要 读 取 的 数据 长 度 。 函 数 能 够 实现 从 filename 指定 
的 文件 中 读 取 一 行 并 返回 长 度 最 大 值 为 length 一 1 个 字 节 的 字符 串 。 在 遇 到 换行 符 、EOF 或 者 读 取 了 
length 一 1 个 字 节 后 停止 。 如 果 没 有 指定 length 的 长 度 ， 默 认 值 是 IKB。 代 码 如 下 : 


<?php 
$f_open = fopen ("../bak/remak.txt","r") ; 1/ 打开 文 本 


Su 
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echo fgets ( $f_open) ; 
fclose ( $f_open ); 


// 读 取 其 中 的 数据 

7> 

readfile() 函 数 的 一 般 格 式 如 下 : 

int readfile ($filename ); 

参数 $filname 为 要 打开 的 文件 名 ， 使 用 该 函数 时 ， 无 须 进行 第 1、3 步 ， 也 无 须 输出 语句 echo， 直 
接 就 可 以 读 取 文件 的 全 部 内 容 并 显示 在 页 面 中 。 

3. 关闭 文件 

完成 对 文件 的 操作 后 ， 就 可 以 关闭 文件 了 。 关 闭 文 件 的 命令 十 分 简单 ， 格 式 如 下 : 

fclose ( $open); 

其 中 参数 $open 是 要 关闭 的 文件 资源 。 


在 本 模块 中 ， 还 用 到 了 两 个 自 定义 函数 c_log() 函 数 和 show_file0 函 数 。c_log(O) 函 数 的 作用 是 删除 
日 志文 件 ， 函 数 程序 代码 如 下 : 


例 程 25 ”代码 位 置 : 光盘 \TM\03\oa\ladmin\inc\func.php 


fonction c log(){ 


S$filename="../log.txt"; /日 志文 件 路 径 

if(file_exists($filename)) // 判 断 文件 是 否 存在 
unlink($filename); // 如 果 文 件 存在 ， 删 除 

else // 如 果 文 件 不 存在 ， 返 回 上 层 操作 


echo "<script>alert(' 暂 无 系统 日 志 ! ');history.go(-1);</script>"; 
} 


show_file() 函 数 的 作用 是 返回 一 个 目录 下 的 所 有 文件 名 列表 ， 并 以 数组 的 形式 返回 。show_file() 函 
数 程序 代码 如 下 : 

例 程 26 ”代码 位 置 ， 光盘 \TM\03\oa\admin\inc\func.php 

function show_file(O){ 


S$folder_name="../bak"; /| 数据 备份 目录 

$d_open = opendir($folder_name); // 打 开 备份 目录 

$num = 0; /| 数组 下 标 

while($file = readdir($d_open){ /循环 读 取 文 件 
$filename[$num] = S$file; // 将 文件 名 存 为 数组 
$num++; 

} 

closedir($d_open); /关闭 目录 

retum S$filename; /返回 文件 数组 


} 


3.11.3 ”系统 日 志 的 实现 过 程 


通过 导航 栏 中 的 “系统 管理 ”/“ 系 统 日 志 ” 可 进入 系统 日 志 页 面 。 在 该 页 面 中 显示 系统 日 志 信 息 ， 
在 系统 日 志 中 ， 记 录 着 前 后 台 ， 包 括 普 通用 户 和 后 台 管理 员 所 有 人 员 登 录 系统 时 的 信息 ， 包 括 登录 时 


“05. 


et 登录 卫 等 


页 面 中 。 


见 本 书 附 带 的 光盘 ) 。 查 看 日 志 页 


。 这 些 信息 是 在 用 户 登 录 时 系统 自 
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面 的 运行 结果 如 图 3.34 所 示 。 


系统 首页 | 重新 登录 | 退出 


ste - | 
清除 日 志 | 
阶 录 账号 登录 时 间 登录 IP 车 录 操作 | 
pe | 
一 一 一 pk T-11-30 08:18:02| 127.0.0.1 | login | 
> | 
ee pk Pooru-a 13:20:19l92. 168. 1.237| legin | 
大 统 日 志 Tsoft pooru-a 15:43:39| 127.0.0.1 login | 
日 数据 备份 1 | 

Tsoft Pr 16:14:49| 127.0.0.1 login 
9 修改 密码 | 
pk poor-l1-a0 16:33:48| 127.0.0.1 login | 
pk poor-u-a 17:32:23he2. 168.1.237| losin | 

tsoft poor-u-a 17:34:04| 127.0.0.1 | login 

图 3.34 系统 日 志 的 运行 结果 
显示 日 志 是 对 文件 进行 读 取 ， 定 位 到 日 志文 件 log.txt 后 ， 使 用 fegs 函数 读 取 日 5 
程序 代码 如 下 : 


例 程 27 ”代码 位 置 ， 光盘 \TM\03\oa\ladmin\xtgl\slog.php 


<?php 
session_start(); 
include "../inc/chec.php"; 
> 
<script sre="../js/admin js.js"></script> 
<link href="../css/style.css" rel="stylesheet"> 


<t> 


// 开 启 session 支 持 
/包含 权限 检查 文件 


/引入 js 脚本 文件 
/引入 外 部 css 样 式 文件 


动 添加 到 数据 表 中 的 〈 关 于 用 户 登 录 的 实 


志 内 容 ， 并 显示 在 


<td colspan="4" height="30" align="center”valign="middle"><a hre 合 "del_slog_chk.php” onclick="retum 


del_chk0);"> 清 除 日 志 </a></td> 


</t> 


<?php 


$filename = "../log.txt"; // 日 志文 件 路 径 
if($f_open = fopen($filename,"r")) // 是 否 以 只 读 形 式 打 开 文 件 
{ 
while($str = feets($f_open,255)){ // 按 行 读 取 日 志文 件 内 容 
S$chr = split(",",$str); /以 “， 
echo "<tr>"; 
for($i = 0; $i < count($chr); $i++){ /循环 输出 字段 值 
echo "<td align= center height="25'>".$chr[$i]."</td>"; } 
echo "</tr>";} 
felose($f_open); /关闭 文件 
} else // 如 果 没 有 日 志文 件 时 


echo "<script>alert(' 还 没有 日 志文 件 ! ");history.go(-1);</script>"; 


Sa. 


”为 分 隔 符 ， 返 回 数组 形式 的 记录 集 
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> 
</table> 
</td></tr></table> 


对 于 无 用 的 日 志 信息 需要 定期 消除 ， 通 过 页 面 中 的 “清除 日 志 ” 超 链接 清空 日 志 ， 实 际 上 就 是 删 
除 日 志文 件 。 程 序 代 码 如 下 : 
例 程 28 ”代码 位 置 ， 光盘 \TM\W3\oavadmin\xtglvdel_slog_chkphp 


<?php 
session_start(); // 开 启 session 支 持 
include "../inc/chec.php"; // 包 含 权限 检查 文件 
include "../inc/func.php"; // 包 含 自 定义 函数 文件 
c_log0; // 调 用 自 定义 函数 
echo "<script>alert(' 删 除 成 功 ! ');location='data_stock.php';</script>"; 

人 > 


3.11.4 数据 备份 的 实现 过 程 


在 病毒 肆虐 的 今天 ， 数 据 备份 的 重要 性 是 毋 需 置疑 的 。 没 有 任何 一 家 网 站 、 一 个 系统 敢 说 自己 是 
绝对 安全 的 ， 只 要 稍 不 留神 就 会 中 招 。 本 着 对 读者 负责 的 态度 ， 在 3.13 小 节 的 技术 专题 中 ， 将 详细 地 
介绍 MySQL 的 备份 与 恢复 ， 以 及 如 何在 php 中 对 MySQL 进行 备份 操作 。 这 里 先 简单 了 解 一 下 本 系统 
数据 备份 的 实现 过 程 。 数 据 备份 页 面 的 运行 结果 如 图 3.35 所 示 。 


办 公 自 动 化 Ee 系 二 百 页 | 重 村 登录 | 退出 
S 村 看 可 站 出 hl8 备 从 

日 币 加 部 站 

TT 区 三] mi200zqi 

Ee 二 四 ETEOEET 司 
9 RR 

一 一 二 

© 账号 权限 

口 。。 用 户 组 设置 

日 权限 分 村 

一 一 一 -一 一 2 

© 系统 日 志 

口 册 据 备份 

© 修改 密码 


3.35 数据 备份 的 运行 结果 


当 单 击 “ 备 份 数据 ”按钮 时 ， 系 统 执行 exec() 函 数 ， 该 函数 的 作用 是 执行 系统 命令 ,通过 系统 命令 
来 备份 数据 。 数 据 备份 的 程序 代码 如 下 : 
例 程 29 ”代码 位 置 ， 光盘 \TM\03\oa\admin\xtgl\data_stock_chk.php 


<?php 


session_start(); // 开 启 session 支 持 
.187 。 g 
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include "../inc/chec.php"; // 包 含 权 限 检查 文件 
$mysqlstr = "D:\\AppServ\IMySQL\bin\mysqldump -uroot -h192.168.1.149 -proot --opt -B db office 
> .bak/".$_POST[b_name]; /数据 库 备 份 语句 
exec($mysqlstr); // 执 行 系统 命令 
echo "<script>alert(' 备 份 成 功 ');location='data_stock.php'</script>"; 
> 


恢复 数据 和 备份 数据 的 执行 过 程 大 同 小 异 , 都 需要 使 用 exec() 函 数 执行 系统 命令 , 只 是 命令 执行 的 
操作 是 完全 相反 的 。 恢 复数 据 的 程序 代码 如 下 : 
例 程 30 ”代码 位 置 ， 光盘 \TM\03\oa\admin\xtgl\rebak_stock_chk.php 


<2?php 
session_start(); // 开 启 session 支 持 
include "../inc/chec.php"; /包含 权限 检查 文件 
$mysqlstr = "D:\\AppServ\\MySQL\\bin\mysql -uroot -h192.168.1.149 -proot db office < .bak/".$ POST[r name]; 
/数据 恢复 命令 
exec($mysqlstr); // 执 行 系统 命令 
echo "<script>alert(' 恢 复 成 功 ');location='data_stock.php'</script>"; 
?> 


删除 数据 备份 实质 就 是 删除 备份 文件 ， 先 使 用 自 定义 函数 show_file0 返 回 一 个 文件 名 列表 数组 ， 
再 使 用 for 循环 语句 ， 逐 一 删除 备份 文件 。 程 序 代码 如 下 : 
例 程 31 ”代码 位 置 ， 光盘 \TM\03\oa\ladmin\xtgl\del_stock_chk.php 


<?php 
session_start(); // 开 启 session 支 持 
include "../inc/chec.php"; // 包 含 权限 检查 文件 
include "../inc/func.php"; // 包 含 自 定义 函数 文件 
Sfilename = show_file(); // 调 用 自 定义 函数 show_file()， 返 回 文件 名 列表 


for($num = 2;$num < count($filename);$num++){ /循环 删除 文件 
unlink("../bak/". $filename[$Snum]); 


} 
echo "<script>alert(' 删 除 成 功 ! ");location='data_stock.php'</script>"; 
Ye 


3.12 ”开发 技巧 与 难点 分 析 


3.12.1 使 用 JavaScript 关联 多 选 列表 框 


在 本 系统 中 ， 多 个 模块 都 使 用 了 这 种 技术 ， 即 在 两 个 多 选 列表 框 之 间 产生 关联 ， 从 列表 框 A 中 删 
除 的 数据 被 相应 的 添加 到 列表 框 B 中 ， 反 之 从 列表 框 B 中 删除 的 数据 会 被 添加 到 列表 框 A 中 。 

在 权限 管理 模块 中 的 用 户 组 设置 ， 就 用 这 种 技术 实现 的 “添加 新 用 户 组 ”功能 ， 首 先 在 左 侧 的 多 
选 列表 框 中 选取 要 添加 的 成 员 ， 单 击 “ 添 加 组 员 ” 超 链接 ， 被 选中 的 成 员 就 被 添加 到 右 侧 列表 框 ， 同 
时 删除 在 左 侧 列表 框 中 的 成 员 ， 运 行 结果 如 图 3.36 所 示 。 
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用 户 组 : 障 时 组 用 户 组 : 陋 时 蛆 
dd ccc 
aaa 
添加 组 员 >> 未 加 组 员 》》 
《< 删除 组 员 << 币 除 组 员 
重 轩 钴 加 | 重 置 | 


图 3.36 ”使 用 JavaScript 关联 多 选 列表 框 


下 面 来 看 一 下 具体 的 操作 ， 首 先 创建 一 个 表单 ， 其 中 两 个 多 选 列表 框 为 必 选 的 表单 元 素 ， 分 别 命 
名 为 left 和 right， 放 在 左 、 右 两 边 ， 其 中 left 列表 框 中 的 数据 是 从 数据 库 中 读 取 的 ，right 列表 框 则 初 
始 为 空 。 程 序 代码 如 下 : 

例 程 32 ”代码 位 置 ， 光盘 \TM\03\oa\ladmin\qxgl\add_group.php 


<!-- 输 出 左 侧 列表 框 --> 
<SELECT name="left" size="10" multiple style="width:100px; "> 
<?php 
while($rows = mysql fetch row($result)){ 
echo "<option value=".$rows[1].">".$rows[1]."</option>"; // 从 数据 库 中 读 取 列 表 值 
} 
> 
</SELECT> 
<1 > 
</td> 
<!--“ 添 加 ”、“ 删 除 ” 超 链接 --> 
<td width="96" align="center" valign="middle"> 
<a href="#" onClick="activeList(document.form1.left,document.form1.right)"> 添 加 组 员 &gt;&gt;</a><br> 
<br 
<a href="#" onClick="activeList(document.forml.right,document.forml Jefb">&lt&lt 删 除 组 员 </a></td> 
<!-- 右 侧 列表 框 -> 
<td colspan="2" align="center" valign="middle"><select name="right" size="10" multiple style="width:100px; "> 
</select></td> 
</tr> 
<tr> 
<td height="30" colspan="4" align="center" valign="middle"> 
<input type="hidden" name="g list" /> 
<L- “添加 ”按钮 -> 
<input type="submit" value=" 添 加 "onclick="retum glist0" /><input type="reset" value=" 重 置 " /> 


上 面 的 代码 主要 是 HTML 和 PHP 语言 ， 和 普通 的 页 面 没有 什么 区 别 , 核心 的 语句 就 是 代码 中 的 加 
粗 部 分 (不 是 注释 ) ， 当 单 击 “ 添 加 组 员 ” 或 “删除 组 员 ” 超 链接 时 ， 将 触发 JavaScript 脚本 事件 ， 执 
行 activeList0 函 数 。 函 数 代码 如 下 : 

例 程 33 ”代码 位 置 ， 光盘 \TM\03\oa\admin\js\admin jsjs 


证 关联 多 选 列表 
*headStream: 源 多 选 列表 
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*endStream: 目的 多 选 列表 


function activeList(headStream,endStream){ 


var valueList = new Array(); 

var textList = new Array(); 

var valueTmpText = new Array(); 
Var index = 0; 


A 存储 源 列表 中 的 被 选中 的 数据 */ 


诈 


在 后 台 的 权限 管理 模块 中 ， 放 弃 了 常用 的 “ 读 ”、 
模式 。 用 户 组 的 设置 主要 是 两 方面 : 一 方面 是 用 户 组 成 员 ， 同 一 用 户 可 以 分 配 在 不 同 的 用 户 组 ， 另 一 
方面 是 功能 列表 ， 可 以 设置 用 户 组 的 访问 权限 ， 不 同 的 用 户 组 ， 所 看 到 的 功能 列表 也 会 不 同 。 这 样 ， 
可 以 使 用 户 的 权利 更 加 细 化 ， 防 止 居心 区 测 的 用 户 恶 意 破坏 。 下 面 是 用 户 组 A 和 用 户 组 B 的 对 比 结果 
图 ， 如 图 3.37 所 示 。 


So. 


for(var i=0; i<headStream.options.length; i++){ 
if(headStream.options[i].selected){ 


valueList[index] = headStream.options[i].value; 
textList[index] = headStream.options[i].text; 


// 数 组 ， 用 来 存储 要 移动 数据 的 value 值 
/数组 ， 用 来 存储 要 移动 数据 的 text 值 
// 数 组 ， 用 来 存储 要 移动 数据 的 option 项 
// 数 组 下 标 


// 判 断 元 素 是 否 被 选中 
/存储 value 值 
// 存 储 text 值 


valueTmpText[valueList[index]] = headStream.options[i]; /存储 option 项 


index ++; 


且 
向 目的 列表 中 添加 数据 ， 同 时 删除 对 应 的 源 列表 数据 


for(var i=0; i<textList.length; i++) { 


var foption = document.createElement("option"); 


foption.text = textList[i]; 
foption.value = valueList[i]; 
endStream.add(foption); 


headStream.removeChild(valueTmpText[valueList[i]]); 


用 


3.12.2 用户 组 设置 


// 建 立新 的 option 项 


// 向 目标 列表 添加 新 建 option 项 
// 从 源 列 表 中 移 除 option 项 


“ 写 ”这 样 的 常规 操作 ， 而 是 采用 了 用 户 组 的 


| 

| 日 一 企业 信息 

| @ 公 司 简介 
| 四 规章 制度 
[Oe 
企业 绩效 

上 @ 任 务 绩效 
上 加 质量 绩效 
| 四 忧 秀 员工 
|- @@ 绩 效 评定 
田地 人 事 消息 

因 地 审核 批示 

加 大考 革 管 理 

回 杖 个 人 计划 

四 大 职员 天 地 


|- 目 忧 秀 员工 
田 夫 人 事 消息 
田 状 审 核 批示 
加 状 考 管理 
加 要 个 人 计划 
田 多 职员 天 地 


3.37 用 户 组 权限 对 比 
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在 功能 列表 的 设置 中 ， 首 先 默认 所 有 的 功能 都 是 可 访问 的 ， 当 有 的 功能 需要 进行 限制 时 ， 就 将 无 
用 的 从 用 户 组 中 删 掉 。 程 序 代码 如 下 : 
例 程 34 ”代码 位 置 ， 光盘 \TM\03\oa\admin\qxgl\pur_assign.php 


<?php 
session_start(); // 开 启 session 支 持 
include "../inc/chec.php"; // 包 含 权限 检查 文件 
include "../conn/conn.php"; // 包 含 数据 库 链 接 文件 
$sqlstr = "select idf_ name,o_group from tb _list"; /生成 SQL 语句 

2> 

<script src=".Jjs/admin jsjs"></script> /引入 js 脚本 文件 

<link href="../css/style.css" rel="stylesheet"> /1/ 引 入 外 部 css 样 式 文件 


<tr><td width="75" height="20" align="center" valign="middle"> 功 能 </td> 
<td width="75" height="20" align="center" valign="middle"> 开 放 组 </td> 
<td width="75" height="20" align="center" valign="middle"> 操 作 </td></tr> 
<?php 
上 ”输出 功能 列表 项 */ 
$result = mysql query($sqlstr,$conn); 
while($rows = mysql_fetch_row($resulb){f 
echo "<tr>"; 
for($i = 1;$i < count($rows); $i++){ 
echo "<td align=center valign=middle>". $rows[S$i]."</td>"; 


} 
echo "<td align=center valign=middle><a href='modify_assign.php?id=".$rows[0]."> 修 改 </a></td>"; 
echo "</tr>"; 


POPP 
> 
</table> 
</td></tr></table> 
本 节 是 3.12.1 节 关 联 多 选 列表 的 延伸 ， 是 具体 应 用 关联 列表 实现 的 一 项 功能 。 在 实际 的 应 用 中 ， 
要 多 多 开动 脑筋 ， 才 能 用 平凡 的 技术 实现 不 平凡 的 功能 。 


3.13 ”MySQL 数据 备份 专题 


关于 备份 数据 的 重要 性 ， 这 里 就 不 再 多 说 了 。 这 小 节 先 来 了 解 常用 数据 库 备 份 的 方式 ， 再 学 习 一 
下 MySQL 数据 备份 与 恢复 的 方式 方法 ， 最 后 看 一 看 在 php 中 是 如 何 对 MySQL 数据 进行 备份 的 。 

1. 数据 库 备份 类 型 

(1) 完全 备份 

这 是 大 多 数 人 常用 的 方式 ， 它 可 以 备份 整个 数据 库 ， 但 它 需要 花费 更 多 的 时 间 和 空间 ， 所 以 一 般 
推荐 一 周 做 一 次 。 

(2) 事务 日 志 备份 

事务 日 志 就 是 对 数据 库 操作 的 记录 ， 它 记录 数据 库 的 改变 ， 备 份 的 时 候 只 需要 备份 自 上 次 备份 以 
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来 对 数据 库 所 做 的 改变 ， 所 以 只 需要 很 少 的 时 间 。 推 荐 每 小 时 一 次 。 

(3) 差异 备份 

也 叫 增 量 备 份 。 它 是 另 一 种 只 备份 一 小 部 分 数据 库 的 方法 ， 它 不 使 用 事务 日 志 ， 相 反 ， 它 使 用 整 
个 数据 库 的 一 种 新 映 象 。 它 比 最 初 的 完全 备份 小 ,因为 它 只 包含 自 上 次 完全 备份 以 来 所 改变 的 数据 库 。 
它 的 优点 是 存储 和 恢复 速度 快 。 推 荐 每 天 做 一 次 。 

(4) 文件 备份 

数据 库 可 以 由 硬盘 上 的 许多 文件 构成 。 如 果 这 个 数据 库 非常 大 ， 忍 怕 一 个 晚上 也 不 能 将 它 备 份 完 ， 
可 以 每 天 备份 数据 库 的 一 部 分 。 由 于 一 般 情 况 下 数据 库 不 会 大 到 必须 使 用 多 个 文件 存储 ， 所 以 这 种 备 
份 不 是 很 常用 。 

2. MySQL 数据 备份 与 恢复 

MySQL 中 的 备份 是 非 六 
下 面 分 别 进行 介绍 。 

(1) 数据 表 备 份 

备份 数据 表 的 语法 如 下 : 


SELECT * INTO OUTFILE ‘file name' FROM tbl name 


的 , 既 可 以 对 单独 的 数据 表 进 行 备份 , 也 可 以 对 整个 数据 库 进行 备份 ， 


回 file name: 备份 的 文件 名 。 如 user.sql。 

回 tbl_name: 备份 的 数据 表 名 。 如 tb_users。 

使 用 该 备份 语句 首先 要 登录 到 MySQL， 并 进入 到 相对 应 的 数据 库 中 ， 如 要 备份 的 表 tb_users 是 属 
于 数据 库 db_office 的 ， 备 份 文件 名 为 users.sql， 则 完整 的 备份 流程 如 图 3.38 所 示 。 


denied for user ’root’@’localhost’ (using password: ¥ 


and Settings dninistratormysql -uroot -hi27?.8.6.1 -p 


elcome to the MySQL monitor- Comnands end with ; or \g- 
our MySQL connection ia is 193 to server version: 5.0.24a-connunity-nt-log 


Ah” for help. Type ’\c’ to clear the huffer. 


changed 
select x into outfile ’ 1’ from th_users; 
Query OK. 5 rows affected <8.80 


Inysql> exit 
Bye 


E:\Documents and Settings dninistrator> 


图 3.38 数据 表 备 份 
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备份 后 的 文件 保存 在 数据 表 所 在 目录 中 ， 如 本 例 中 表 tb_users 所 在 的 目录 为 D:\AppServ\MySQI\ 
datavdb_office， 则 备份 的 sql 文件 就 保存 在 这 个 路 径 下 。 
如 果 要 恢复 备份 文件 ， 代 码 如 下 : 


LOAD DATA INFILE 'usersql REPLACE into table ‘tb_users' 
(2) 数据 库 备份 
数据 库 备 份 时 ， 可 以 不 用 登录 到 sql 里 ， 直 接 使 用 mysqldump 命令 即 可 。 该 命令 格式 如 下 : 
mysqldump -uroot -proot db_office > c:\emark .txt 
备份 的 数据 表 ， 实 际 就 是 一 个 完整 的 建 库 流 程 ， 如 果 要 恢复 备份 ， 直 接 用 MySQL 命令 即 可 。 语 
名 如 下 了 
mysql -uroot -proot db_office < c:\\remark.txt 
mysqldump 语句 的 功能 十 分 强大 ， 备 份 只 是 其 中 的 一 个 功能 ， 感 兴趣 的 读者 可 以 参考 mysqldump 
的 帮助 文档 。 
3. 在 PHP 中 备份 数据 库 
在 PHP 中 备份 数据 库 ， 主 要 通过 exec() 函 数 执行 系统 命令 。 
exec() 函 数 的 格式 为 : 
String exec ( string command ) 
参数 command 为 要 执行 的 系统 命令 。 这 里 为 备份 数据 表 的 命令 ， 代 码 如 下 : 
exec("D:\\AppServ\\IMySQL\bin\mysqldump -uroot -h192.168.1.149 -proot --opt -B db_office > ../bak/remark.sql"); 
全 注意 : 虽然 在 安装 时 MySQL 已 经 设置 了 环境 变量 ， 但 如 果 要 在 PHP 中 执行 mysqldump、mysql 命 
令 ， 则 必须 给 出 命令 的 完整 路 径 ; 否则 ， 就 会 出 现 文件 大 小 为 OKB 的 结果 。 


3.14 ”本章 总 结 


本 章 通过 一 个 完整 的 办 公 自 动 化 管理 系统 开发 过 程 ， 向 读者 讲述 了 系统 开发 的 几 个 重要 环节 ， 还 
包括 几 个 主要 模块 的 功能 实现 。 最 后 又 着 重 学 习 了 MySQL 备份 的 相关 知识 ， 相 信 通 过 本 章 的 学 习 ， 
读者 对 如 何 开发 一 个 真实 的 项 目 有 了 进一步 的 了 解 。 相 信 读 者 通过 自己 动手 实践 ， 完 成 一 个 功能 相似 
的 办 公 自 动 化 管理 系统 是 完全 不 成 问题 的 。 
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第 章 


电子 商务 平台 网 


( Apache+PHP+phpMyAdmin+MySQL 5.0 实现 ) 


电子 商务 源 于 英文 ELECTRONIC COMMERCE， 简 写 为 EC。 顾 名 思 义 ， 其 内 
容 包含 两 个 方面 : 一 是 电子 方式 ， 二 是 商贸 活动 。 

EC (电子 商务 ) 指 的 是 利用 简单 、 快 捷 、 低 成 本 的 电子 通信 方式 ， 买 卖 双方 不 
谋面 而 在 网 上 开展 的 各 种 商贸 活动 。 在 全 球 知识 经 济 和 信息 化 高 速 发 展 的 今天 ， 信 
息 化 是 决定 企业 成 败 的 关键 因素 , 信息 的 有 效 利用 成 为 新 经 济 模式 中 企业 增强 竞争 
力 的 重要 手段 。 

电子 商务 作为 一 种 新 新 的 商务 运作 模式 ， 越 来 越 受 到 企业 的 重视 。 电 子 商务 的 
魅力 在 于 它 能 打 碎 现存 的 一 切 链条 结构 ， 让 产品 群 、 客 户 群 、 技 术 群 、 物 流 群 等 重 
新 排队 、 优 化 组 合 ， 为 企业 业务 的 重新 组 合 提供 无 限 商机 ， 开 辟 新 的 竞争 领域 ， 形 
成 新 的 利益 分 配 格局 。 本 章 通过 开发 一 个 流行 的 电子 商务 网 站 一 一 电子 商务 平台 
网 ， 快 速 开发 一 个 电子 商务 平台 。 通 过 阅读 本 章 ， 可 以 学 习 到 : 


项 目 需求 分 析 和 系统 设计 的 方法 

在 MySQL 中 创建 数据 库 、 数 据 表 的 不 同方 法 
如 何 设 计 公 共 类 

实现 购物 车 的 原理 

打印 订单 技术 

单元 测试 的 方法 

网 站 安全 技术 

加 密 技术 


豆 吾 吾 吾 于 于 吾 至 
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4.1 开发 背景 


随 着 我 国 网 络 经 济 的 快速 发 展 ， 互 联网 用 户 数 逐 日 增多 ， 有 过 网 络 购物 经 历 的 用 户 达 到 3000 万 人 
以 上 ， 其 中 有 一 半 人 数 已 经 习惯 网 上 购物 ， 而 且 这 个 数目 正在 快速 增长 。 以 商品 销售 为 主 的 某 商城 目 
前 正面 临 竞争 和 效益 下 降 的 压力 ， 每 天 的 内 部 工作 流程 都 需要 花费 大 量 成 本 ， 为 了 不 受 传统 方式 的 约 
束 ,减少 过 多 成 本 和 人 员 的 开销 ， 增 强 企 业 的 竞争 力 ， 该 商城 决定 采用 电子 商务 模式 ， 向 多 元 化 发 展 ， 
借助 Internet 在 国内 的 快速 发 展 ， 在 建立 企业 宣传 网 络 的 同时 ， 也 逐步 扩大 企业 自身 的 网 络 销售 渠道 ， 
聚集 部 分 资金 投入 网 站 建设 。 通过 网 上 交易 为 主要 形式 ， 进 行 网 络 交 易 的 过 渡 ， 带动 商城 的 快速 发 展 ， 
快速 提高 企业 的 经 济 效益 。 企 业 通过 建立 自己 独 有 的 网 上 交易 平台 ， 为 消费 者 提供 安全 、 便 捷 的 购物 
方式 , 为 商家 提供 交易 处 理 和 丰富 的 管理 功能 。 现 需要 委托 某 单位 开发 一 套 完 整 的 电子 商务 管理 平台 ， 
从 而 能 以 低 成 本 为 消费 者 提供 更 快 更 好 的 服务 。 


4.2 系统 分 析 


在 开发 一 个 项 目 之 前 ， 首 先 要 对 所 开发 的 项 目 进行 需求 分 析 、 可 行 性 分 析 ， 以 使 项 目 开发 人 员 了 
解 和 掌握 网 站 的 前 期 策划 和 网 站 开发 流程 。 


4.2.1 需求 分 析 


随 着 Internet 的 发 展 ， 电 子 商务 将 成 为 21 世纪 网 络 发 展 的 主流 ， 网 上 购物 将 成 为 一 种 购物 时 尚 
它 为 人 们 提供 了 网 络 购物 的 方便 性 ， 使 顾客 可 以 足 不 出 户 就 可 以 购买 商品 。 现 在 流行 的 电子 商务 有 
B2B、B2C、C2C、G2C 等 类 型 。 电 子 商 务 平台 网 是 建立 在 企业 与 消费 者 (B2B 类 型 ) 之 间 的 商务 交易 
网 站 ， 它 可 以 使 顾客 通过 浏览 商品 、 网 络 购物 、 查 询 订单 、 打 印 订 单 和 查看 公告 等 功能 购买 自己 所 需 
的 商品 。 通 过 对 一 些 典型 电子 商城 网 站 的 考察 、 分 析 ， 并 结合 企业 要 求 以 及 实际 的 市 场 调查 ， 要 求 本 
系统 具有 以 下 功能 
网 站 设计 页 面 要 求 美观 大 方 、 个 性 化 ， 能 够 展示 企业 形象 。 

网 站 页 面具 有 banner 广告 ， 树 立 企业 良好 的 口碑 宣传 。 

设计 完全 从 网 络 营销 的 角度 设计 ， 不 花 钱 就 可 以 被 世界 各 大 搜索 引擎 收录 。 
企业 所 有 的 商品 数据 都 在 电子 商务 平台 中 展示 。 

规范 、 完 善 的 基础 信息 设置 。 

j 品 分 类 详尽 ， 可 按 不 同类 别 查看 商品 信息 。 

按 商品 大 类 及 商品 名 称 、 订 单 进行 模糊 查询 。 

实现 选 购 商品 一 订购 商品 一 收银 结账 一 打印 订单 功能 。 

实现 各 种 查询 ， 如 模糊 查询 、 高 级 查询 等 。 

管理 员 对 用 户 订单 进行 管理 。 


回 


Sl 
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提供 了 交互 式 的 销售 渠道 。 使 商家 能 及 时 得 到 顾客 反馈 信息 ， 了 解 顾客 需求 ， 改 进 本 身 的 工作 。 
4.2.2 可 行 性 分 析 


可 行 性 分 析 的 目的 就 是 要 用 最 小 的 代价 在 尽 可 能 短 的 时 间 内 确定 问题 是 否 能 够 解决 ， 当 然 不 能 靠 于 
观 猜想 而 是 要 靠 客观 分 析 。 必 须 分 析 解 法 的 利 浆 ， 从 而 判定 系统 目标 和 规模 是 否 现实 ， 系 统 完成 后 所 生 
带 来 的 效益 是 否 大 到 值得 去 投资 开发 这 个 系统 的 程度 。 因 此 ， 可 行 性 分 析 实 质 上 是 要 进行 依次 大 大 地 压 
缩 简 化 了 的 系统 分 析 和 设计 的 过 程 ， 也 就 是 在 较 高 层次 以 较 抽象 的 方式 进行 的 系统 分 析 和 设计 的 过 程 。 

该 软件 项 目 可 行 性 研究 报告 是 对 项 目 课题 的 全 面 通盘 考虑 ， 是 项 目 分 析 员 进一步 工作 的 前 提 ， 是 软件 
开发 人 员 正 确 成 功 的 开发 项 目的 前 提 与 基础 。 编 写 可 行 性 研究 报告 可 以 使 软件 开发 团体 尽 可 能 早 的 估计 研 
制 课题 的 可 行 性 ， 可 以 在 定义 阶段 较 早 的 认识 到 系统 方案 的 缺陷 ， 从 而 节约 开发 时 间 和 精力 、 节 省 资金 ， 
并 且 避 免 了 许多 专业 方面 的 困难 ， 所 以 特意 编写 该 软件 项 目 可 行 性 研究 报告 ， 意 在 起 到 事半功倍 的 效果 。 

电子 商务 平台 网 的 可 行 性 可 从 以 下 两 点 考虑 : 
回 经济 可 行 性 分 析 。 电 子 商 务 网 站 的 宗旨 是 根据 用 户 需 求 和 市 场 形 势 ， 提 供 商品 的 详细 信息 ， 
并 对 商品 进行 详细 分 类 ， 方 便 用 户 查 找 和 购买 所 需 的 商品 。 

加 ”技术 可 行 性 分 析 。 电 子 商 务 网 站 提供 购物 车 和 收银 台 功 能 ， 用 户 选择 商品 并 可 以 在 线 提交 订 
单 ; 信息 管理 系统 实现 对 商品 信息 、 用 户 信息 、 订 单 信息 以 及 交易 制度 等 的 管理 ， 使 网 站 有 具 
有 友好 的 交易 界面 和 良好 的 管理 平台 。 


4.3 系统 设计 


出 


EC 


4.3.1 系统 目标 


旺 


目前 Intermet 网 上 商家 不 少 ,但 由 于 缺乏 相应 的 安全 保障 、 管 理 机 制 、 操 作 便捷 和 可 维护 性 ， 造 成 如 
复 建设 和 资源 浪费 。 一 个 网 上 购物 网 站 ， 尤 其 是 数据 流量 比较 大 的 网 络 管理 系统 ， 必 须要 满足 使 用 方便 、 
操作 灵活 等 设计 需求 。 根 据 需 求 分 析 的 描述 以 及 与 用 户 的 沟通 ,本 系统 在 设计 时 应 该 满足 以 下 儿 个 目标 : 
系统 采用 人 机 对 话 方式 ， 界 面 设计 美观 大 方 、 方 便 、 快 捷 、 准 确 ， 数 据 存储 安全 可 靠 。 

全 面 展 示 商 城内 所 有 商品 ， 并 可 以 展示 最 新 商品 、 推 荐 商品 、 热 门 商品 。 

实现 各 种 查询 ， 如 模糊 查询 、 高 级 查询 等 。 

查看 商城 内 的 公告 信息 。 

灵活 快速 的 填写 供求 信息 ， 使 信息 传递 更 快捷 。 

为 充分 展现 网 站 的 交互 性 ， 本 系统 实现 “网 上 用 户 订购 一 支付 一 发 货 ” 一 条 链 路 。 


加 


实现 订单 打印 功能 。 
对 用 户 输入 的 数据 ， 系 统 进行 严格 的 数据 检验 ， 尽 可 能 排除 人 为 的 错误 。 
支持 友情 链接 功能 。 


网 站 最 大 限度 地 实现 了 易 维护 性 和 易 操 作 性 。 
系统 运行 稳定 、 安 全 可 靠 。 
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4.3.2 ”系统 功能 结构 


为 了 使 读者 能 够 更 清楚 地 了 解 网 站 的 结构 ， 下 面 给 出 电子 商务 网 站 的 前 台 功 能 模块 结构 图 和 后 台 
功能 模块 结构 图 。 
电子 商务 平台 网 前 台 管理 系统 的 功能 设计 如 图 4.1 所 示 。 


电子 商务 平台 前 台 管 理 系统 


州 莹 泛 对 再 


| 
修改 个 人 信息 修改 密码 


图 4.1 前 台 功 能 模块 结构 图 
电子 商务 平台 网 后 台 管理 系统 的 功能 设计 如 图 4.2 所 示 。 


电子 商务 平台 后 台 管理 系统 


商 || 添 | | 用 | | 用 | | 里 n 
商 | | 商 || 强 | | 总 | | 息 | | 量 | | 再 订 | | 订 管 | | 公 | | 管 
品 || 品 | | 管 || 奖 | | 党 | | 香 | | 号 音 理 | | 着 | | 悍 

理 || 别 | | 型 | | 理 | | 息 


图 42 后 台 功 能 模块 结构 图 
4.3.3 ”购物 流程 图 


所 谓 电子 商务 ， 其 实质 就 是 建立 一 个 虚拟 的 购物 超市 ， 当 在 超市 选 购 商品 时 ， 首 先 应 将 商品 放 到 
购物 车 中 ， 待 挑选 好 所 有 商品 之 后 就 可 以 到 收银 台 去 开 收 货 单 ， 根 据 收 货 单据 付款 。 制 作 电 子 商 务 系 
统 的 原理 与 在 超市 购物 的 原理 是 一 样 的 。 首 先 客户 应 该 在 网 页 中 选 购 自己 需要 的 商品 并 将 商品 放 入 购 
物 车 中 ， 当 然 也 可 以 改变 购买 商品 的 数 或 清空 购物 车 中 的 商品 。 选 购 好 商品 后 就 可 以 到 收银 台 ， 在 收 
银 台 进行 填写 收 货 人 信息 、 提 交 收 货 人 信息 、 查 看 账单 等 操作 。 
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由 于 系统 的 定位 是 一 个 网 上 的 购物 系统 ， 是 一 个 电子 商务 类 网 站 。 传 统 的 C/S (客户 机 /服务 器 ) 
日 ， 需 要 的 是 B/S〈 浏 览 器 /服务 器 ) 架构。 根据 上 面 的 分 析 ， 


已 经 不 适应 了 ， 作 为 Internet 上 的 Web 应 月 
笔者 将 采用 PHP 这 种 相对 流行 而 且 安全 性 较 高 的 Web 开发 语言 ， 同 时 使 用 PHP 的 黄金 搭档 MySQL 
作为 后 台数 据 库 。 电 子 商务 平台 的 购物 流程 如 图 4.3 所 示 


电子 商务 网 站 
RN 


是 浏览 网 站 
其 他 功能 模块 


进行 商品 信息 管理 、 
订单 管理 .用 户 管理 、 


网 站 信息 管理 昌 
正 
是 


时 
购物 车 


更 改 商 品 数量 


4.3 ”电子 商务 平台 的 购物 流程 图 


4.3.4 系统 预览 
电子 商务 平台 网 由 多 个 程序 页 面 组 成 ， 下 面 仅 列 出 几 个 典型 页 面 ， 其 他 页 面 参见 光盘 中 的 源 程序 
示 公告 信息 、 友 情 链 接 、 商 品 信 


前 台 首 页 如 图 4.4 所 示 ， 该 页 面 用 于 实现 商品 信息 展示 、 用 户 登录 、 
后 台 首页 如 图 4.5 所 示 ， 该 页 面 用 于 实现 查看 订单 、 执 行 订 单 、 删 除 订单 、 打 印 订 单 等 


息 查 询 等 功能 。 后 
功能 。 
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图 4.4 前 台 首页 (光盘 \TM\04\shop\index.php) 图 4.5 后 台 首 页 (光盘 \TM\04\shop\admin\default.php) 

会 员 信息 管理 页 面 如 图 4.6 所 示 ， 该 页 面 用 于 实现 修改 个 人 信息 、 修 改 密码 、 用 户 留言 、 用 户 注销 
等 功能 。 购 物 车 列表 页 面 如 图 4.7 所 示 ， 该 页 面 用 于 实现 查看 购物 车 、 移 除 购物 商品 、 修 改 商 品 数量 、 
清空 购物 车 、 收 银 台 结 账 、 生 成 订单 等 功能 。 


LE 


图 4.6 会 员 信 息 管理 (光盘 \TM\04\shop\usercenter.php) 图 4.7 购物 车 列表 (光盘 \TM\04\shop\gouwul.php) 


用 户 订单 查询 页 面 如 图 4.8 所 示 , 该 页 面 用 于 实现 按 下 单 人 或 订单 号 进行 订单 信息 查询 功能 。 管理 
员 登 录 页 面 如 图 4.9 所 示 ， 该 页 面 用 于 实现 对 管理 员 登 录 的 用 户 名 和 密码 进行 验证 等 功能 。 


图 4.8 用户 订 单 查 询 (光盘 \TM\04\shop\admin\finddd.php) 图 4.9 管理 员 登 录 ( 光 盘 \TM\04\shop\admin\index.php) 
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4.3.5 开发 环境 


在 开发 电子 商务 平台 网 时 ， 该 项 目 使 用 的 软件 开发 环境 如 下 : 
.服务 器 端 

操作 系统 : Windows 2003 Server/Linux (推荐 ) 。 
服务 器 : Apache 2.2。 

PHP 软件 : PHP 5.1.6。 

数据 库 : MySQL 5.0.24。 

MySQL 图 形 化 管理 软件 : phpMyAdmin-2.9.0.2。 
开发 工具 : Dreamweaver 8 。 

浏览 器 : IE 6.0 及 以 上 版 本 。 

分 辨 率 ， 最 佳 效 果 1024X 768 像素 。 
客户 端 : 

浏览 器 :IE 6.0 及 以 上 版 本 。 

分 辨 率 : 最 佳 效 果 1024X768 像素 。 


国 加 图 回国 图 图 罗 一 


风 国 : 间 


4.3.6 文件 夹 组 织 结构 


在 进行 网 站 开发 前 ， 首 先 要 规划 网 站 的 架构 。 也 就 是 说 ， 建 立 多 个 文件 夹 ， 对 各 个 功能 模块 进行 
划分 ， 实 现 统 一 管理 ， 这 样 做 易于 网 站 的 开发 、 管 理 和 维护 。 本 案例 的 站 点 管理 规划 如 图 4.10 所 示 。 


马 shop 
村 加 adnin 一 一 一 一 一 一 一 一 一 一 用 于 存储 网 站 后 台 交 件 
夺 国 css 一 一 一 一 一 一 一 一 一 一 用 于 存 诸 网 站 前 台 使 用 的 CS5 样式 表 
com 用 于 存储 后 台数 据 库 连接 净 件 
: HD inages 用 于 存储 网 站 后 台 页 面 使 用 的 图 片 文件 
”轩辕 Wpinages 一 一 一 一 一 一 一 一 用 于 存 导 网 站 后 台 页 面 使 用 的 上 传 图 片 文件 
HH 加 “一 用 于 存 情 网 站 前 台 使 用 的 CSS 样式 表 
HD data 用 于 存 情 数 据 库 文件 
HD inages 用 于 存储 网 站 前 人 台 页 面 使 用 的 图 片 交 件 
村 -加 com 用 于 存储 前 台数 据 库 连接 交 件 


图 4.10 文件 夹 组织 结 构 
4.4 数据 库 设计 


电子 商务 平台 网 是 一 个 数据 库 开 发 应 用 程序 。 本 节 针 对 电子 商务 平台 网 的 数据 库 设计 进行 详细 
。200 。 
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介绍 。 
4.4.1 数据 库 分 析 


由 于 本 系统 是 为 中 小 型 的 图 书馆 开发 的 程序 ， 需 要 充分 考虑 到 成 本 问题 及 用 于 需求 〈 如 器 平台) 
等 问题 ， 而 MySQL 是 世界 上 最 为 流行 的 开放 源码 的 数据 库 ， 是 完全 网 络 化 的 跨 平台 的 关系 型 数据 库 
系统 , 这 正好 满足 了 中 小 型 企业 的 需求 ,所 以 本 系统 采用 MySQL 数据 库 。 作 为 PHP 的 黄金 搭档 MySQL 
数据 库 不 仅 存储 和 管理 功能 强大 ， 而 且 它 是 完全 免费 提供 的 ， 很 多 网 站 都 可 以 下 载 到 它 ， 这 样 可 以 为 
企业 节省 很 大 一 部 分 开支 -PHP 中 也 提供 了 强大 的 支持 MySQL 数据 库 的 函数 ,phpMyAdmin 为 MySQL 
数据 库 提供 了 图 形 化 界面 。 


4.4.2 数据 库 概念 设计 


根据 以 上 各 节 对 系统 所 做 的 需求 分 析 、 系 统 设计 ， 规 划 出 电子 商务 平台 的 实体 关系 E-R 图 。 实 体 
关系 E-R 图 是 用 来 描述 实体 之 间 关 系 的 图 表 ， 构 成 E-R 图 的 基本 要 素 是 实体 型 、 属 性 和 联系 ， 其 表示 
方法 为 : 

实体 型 : 用 和 矩形 表示 ， 和 矩形 框 内 标注 实体 名 。 

属性 : 用 椭圆 形 表示 ， 并 用 无 向 边 将 其 与 相应 的 实体 连接 起 来 。 

联系 : 用 菱形 表示 ， 菱 形 框 内 标注 联系 名 ， 并 用 无 向 边 分 别 与 有 关 实 体 连接 起 来 ， 同 时 在 无 

向 边 旁 标 上 联系 的 类 型 (1:1、1:n 或 m:n) 。 

本 系统 中 使 用 的 数据 库 实体 分 别 为 商品 信息 实体 、 商 品类 型 实体 、 用 户 信息 实体 、 用 户 订单 实体 、 
用 户 留言 实体 、 商 品评 价 实体 、 管 理 员 信 息 实体 、 公 告 信息 实体 和 友情 链接 实体 。 下 面 将 介绍 儿 个 关 
键 实体 的 E-R 图 。 

1. 商品 信息 实体 

商品 信息 实体 包括 编号 、 名 称 、 价 格 、 上 市 时 间 、 等 级 、 型 号 、 图 片 路 径 、 数 量 、 购 买 次 数 、 是 
和 否 推荐 、 商 品类 型 、 会 员 价 、 市 场 价 、 商 品 品牌 等 属性 。 商 品 信息 实体 的 E-R 图 如 图 4.11 所 示 。 


4.11 商品 信息 实体 ER 
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2. 商品 订单 实体 

商品 订单 实体 包括 编号 、 订 单 号 、 商 品 串 、 数 量 串 、 收 货 人 姓名 、 收 件 人 性 别 、 送 货 地 址 、 邮 编 、 
联系 电话 、E-mail、 收 货 方 式 、 支 付 方式 、 用 户 留 言 、 下 单 时 间 、 下 单 人 姓名 、 订 单 状态 、 价 格 总 计 等 
属性 。 商 品 订单 实体 的 E-R 图 如 图 4.12 所 示 。 


数量 串 


收 货 人 


送 货 地 址 


图 4.12 商品 订单 实体 E-R 图 
3. 用 户 信息 实体 
用 户 信息 实体 包括 编号 、 用 户 名 、 加 密 密 码 、 冻 结 标记 、E-mail、 身 份 证 号 、 联 系 电 话 、QQ 号 、 
密码 提示 、 密 码 答案 、 邮 编 、 注 册 时 间 、 真 实 姓名 、 密 码 等 属性 。 用 户 信 息 实体 的 E-R 图 如 图 4.13 
所 示 。 


图 4.13 用 户 信息 实体 E-R 图 


4. 商品 评价 实体 
商品 评价 实体 包括 编号 、 用 户 编号 、 商 品 编号 、 评 价 主题 、 评 价 内 容 、 评 价 时 间 等 属性 。 商 品评 
价 实体 的 E-R 图 如 图 4.14 所 示 。 


Sm 
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商品 评价 


图 4.14 商品 评价 实体 ER 
4.4.3 创建 数据 库 及 数据 表 


结合 实际 情况 及 对 用 户 需求 的 分 析 ， 电 子 商务 系统 db_shop 数据 库 主 要 包含 如 下 9 个 数据 表 ， 如 
图 4.15 所 示 。 


力 服务 器 : localhost ， 曲 数据 库 : db_shop 

表 类 型 整理 说 明 
th_admin MyISAM gb2312_chinese_ci 管理 员 信 息 表 
tb_dingdan MylSAM gb2312_chinese_ci 订单 信息 表 
tb_gonggao MylSAM gb2312_chinese_ci 公告 信息 表 
th_leaveword MYyISAM gb2312_chinese_ci 用 户 留言 信息 表 
tb_links MyISAM gb2312_chinese_ci 友情 链接 信息 表 
th_pingjia MylSAM gb2312_chinese_ci 商品 评价 信息 表 
th_shangpin MylSAM gb2312_chinese_ci 商品 信息 表 
tb MyISAM ”gb2312_chinese_ci 商品 类 型 信息 表 
th_user MyISAM gb2312_chinese_ci 用 户 信息 表 


图 4.15 ”电子 商务 系统 数据 表 

下 面 以 db_shop 数据 库 中 的 tb_admin 数据 表 为 例 ， 通 过 两 种 不 同 的 方法 来 讲解 数据 库 及 数据 表 的 
创建 过 程 。 

1. 在 命令 提示 符 下 创建 数据 库 及 数据 表 

在 数据 库 脚 本 文件 导出 后 ， 就 可 以 根据 该 脚本 文件 在 MySQL 中 创建 数据 库 及 数据 表 了 。 具 体 步 
又 如 下 : 

(1) 选择 “开始 ”/“ 所 有 程序 ”/“Appserv”/“MySQL Command Line _ Client” 命令， 进入 到 
MySQL 的 客户 端 命令 行 窗口 , 输入 密码 并 按 Enter 键 后 , 即 可 使 用 MySQL Client 连接 MySQL 数据 库 。 

(2) 在 mysql> 提 示 符 后 面 输入 以 下 命令 创建 数据 库 db_shop。 

"203 。 乡 
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create database db_shop; 
(3) 调用 数据 库 db_shop。 
use db_shop; 
(4) 在 数据 库 db_shop 中 创建 一 个 简单 的 数据 表 tb_admin， 包 括 id、name、pwd 等 字段 ， 代 码 
如 下 : 


mysql> create table tb admin( 
->idintAUTO INCREMENT PRIMARY KEY, 
-> name varchar(13) NOTNULL, 
-> pwd varchar(50) NOTNULL, 
Query OK, 0 rows affected (0.03 sec) 


从 技巧 : 在 输入 SQL 语句 时 , 可 以 一 行 全 部 输出 , 也 可 以 每 个 字段 都 换行 输出 ， 这 里 建议 换行 输出 ， 
这 样 看 上 去 美观 、 易 懂 ， 在 语句 出 现 错误 时 更 容易 查找 。 

2. 在 phpMyAdmin 图 形 化 工具 下 创建 数据 库 和 数据 表 

在 phpMyAdmin 的 主 界面 中 有 两 个 文本 框 和 “创建 ”按钮 ， 首 先 在 文本 框 中 输入 数据 库 的 名 称 ， 
然后 选择 编码 , 最 后 单 击 “ 创建 按钮 , 这 样 新 的 数据 库 就 可 以 被 创建 成 。 例 如 , 创建 一 个 名 称 为 db_shop 
的 数据 库 ， 首 先 在 文本 框 中 输入 db_shop， 之 后 在 下 拉 列 表 框 中 找到 要 使 用 的 编码 ， 在 Windows 下 一 
般 选 择 gb2312_chinese_ci， 如 图 4.16 所 示 。 

习 localhost 


加 服务 器 版 本 : 5 0.24a-community-ntlog 


phpldy ， Protocol version: 10 
可 司 回 四 服务 器 localhost via TCP/IP 
， 用 户 : root@localhost 
数据 库 到 MySQL 字符 集 : UTF-8 Unicode (utf8) 
0 M4 贺 YysQL 连接 校对 : [062312_chinese_ci 司 @ 


喇 名 创建 一 个 新 的 数据 库 @ 
于 显示 MySQL 的 运行 信息 
图 显示 MySQL 的 系统 变量 @ 选择 编码 格式 


图 4.16 phpMyAdmin 管理 界面 
最 后 单 击 “ 创 建 ” 按 扭 ， 这 样 名 为 db_shop 的 数据 库 就 被 创建 成 功 。 执 行 结果 如 图 4.17 所 示 。 


斑纹 在 数据 库 db_shop 中 创建 一 个 新 表 
名 字 人 (4tb admin 7) 


Number offields(3 ) 


输入 新 表 字 段 个 数 
图 4.17 数据库 的 建立 
S 。204 。 
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在 右 侧 界面 还 可 以 执行 创建 数据 表 的 操作 ， 首 先 在 表单 中 输入 数据 表 的 名 称 和 字段 数 ， 然 后 单 击 
“执行 ”按钮 ， 进 入 各 个 字段 的 详细 信息 录入 表单 ， 包 括 字段 名 、 数 据 类 型 、 长 度 / 值 、 属 性 、 默 认 值 、 
额外 和 索引 的 类 型 等 。 在 这 里 就 完成 了 对 表 结 构 的 详细 设置 ， 如 图 4.18 所 示 。 

轩 服务 器 : localhost ， 章 数据 库 : db_shop ， 国 表 :tb_admin 


字段 类 型 回 长 度 时 :1 整理 Null 额外 

四 INT | [gb2312_ chinese_ct 司 [notnu 司 [auo neement 同 © C 
[name [vrchara 司 [ss [gb2312_chinese -ct 司 [notnu 司 | 三 嘎 = 
[owa [varchara 司 同 [9b2312_chinese_ci 司 [noatnu 司 | 站 | ww 
保存 | 或 添加 | 字段 执行 


图 4.18 创建 表 信息 


总 技巧 : 创建 MySQL 数据 库 的 方法 主要 有 两 种 : 一 种 方法 是 在 命令 提示 符 下 通过 输入 SQL 语句 创 
建 ， 但 这 种 方法 相对 效率 较 低 ， 对 SQL 语句 不 是 特别 熟悉 的 初学 者 来 说 也 是 非常 困难 的 。 
另 一 种 是 应 用 数据 库 图 形 化 管理 工具 phpMyAdmin 创建 ， 后 面 这 种 方法 操作 上 更 直观 、 更 
便捷 ， 它 可 以 高 效 地 完成 数据 库 的 设计 。 
结合 该 数据 表 的 创建 方法 ， 读 者 可 以 自行 创建 以 下 数据 表 。 数 据 表 的 设计 结构 如 图 4.19~ 图 4.24 
所 示 。 
(1) tb_shangpin〔 商 品 信息 表 ) 
商品 信息 表 主要 用 于 存储 商品 的 基础 信息 。 该 数据 表 结构 如 图 4.19 所 示 。 


胃 服务 器 : localhost ， 曲 数据 库 : db_shop ， 国 表 :tb_shangpin 


字段 类 型 整理 Null ”默认 额外 说 明 
这 int(4) 否 auto_increment ”自动 编号 这 
mingcheng varchar(25) gb2312_chinese_ci 是 NULL 商品 名 称 
jianjie mediumtext gb2312_chinese_ci 是 NULL 商品 价格 
addtime varchart25) ”gb2312_chinese_ci 是 NULL 入 市 时 间 
dengji Yarcharf5) gb2312_chinese_ci 是 NULL 商品 等 级 
xinghao varchar(25) ”gb2312_chinese_ci 是 NULL 商品 型 号 
tupian Yarchar(200) gb2312_chinese_ci 是 NULL 图 片 路 径 
shuliang int(d) 是 NULL 商品 数量 
cishu int4) 是 NULL 购买 次 数 
tuijian int(4) 是 NULL 是 否 推荐 
typeid int(d) 是 NULL 类 型 记 
huiyuanjia varchar(25) gb2312_chinese_ci 是 WULL 会 员 价 


和 
局 

上 
才 
或 
S 


shichangjia varchar(25) gb2312_chinese_ci 
pinpai Yarchar(25) gb2312_chinese_ci 


和 
EE 
| 号 
型 
3 
办 


图 4.19 商品 信息 表 
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(2) tb_dingdan (用 户 订单 表 ) 


用 户 订单 表 主 要 用 于 存储 用 户 的 订单 信息 。 该 数据 表 结 构 如 图 4.20 所 示 。 
困 服务 器 : localhost ， 曲 数据 库 : db_shop ， 国 表 :tb_dingdan 

字段 类 型 整理 Null ”默认 额外 说 明 
id inttd) 否 auto_increment ”自动 编号 这 
dingdanhao varchart125) gb2312_chinese_ci 是 NULL 订单 号 
spc varchart125) gb2312_chinese_ci 是 NULL 商品 
slc varchart125) yb2312_chinese_ci 是 NULL 数量 审 
shouhuoren varchar(25) gb2312_chinese_ci 是 NULL 收 货 人 姓名 
Sex Yarchar(2) gb2312_chinese_ci 是 NULL 收 件 人 性 别 
dizhi varchart125) gb2312_chinese_ci 是 NULL 送 货 地 址 
youbian varchar(10) ”gb2312_chinese_ci 是 NULL 邮编 
tel varchart25) ”gb2312_chinese_ci 是 NULL 联系 电话 
email varchart25) ”gb2312_chinese_ci 是 NULL Email 
Shff warchar(25) ”gb2312_chinese_ci 是 NULL 收 货 方式 
zfff varchar(25) ”gb2312_chinese_ci 是 NULL 支付 方式 
leaveword mediumtext gb2312_chinese_ci 是 NULL 用 户 留言 
time varchar(25) ”gb2312_chinese_ci 是 NULL 下 单 时 间 
xiadanren varchart25) ”gb2312_chinese_ci 是 NULL 下 单 人 姓名 
zt vyarchar(50) ”gb2312_chinese_ci 是 NULL 订单 状态 
total varchar(25) ”gb2312_chinese_ci 是 NULL 价格 总 计 


图 4.20 用 户 订单 表 


(3) tb_admin (管理 员 表 ) 


管理 员 表 和 


(4) tb_user〈 用 
用 户 信息 表 主 要 用 于 存储 


NE 


E 要 用 于 存储 管理 员 的 信息 。 该 数据 表 结 构 如 图 4.21 所 示 。 


图 服务 器 : localhost ， 昌 数据 库 : db_shop ， 国 表 : tb_admin 


字段 


这 


类 型 整理 Null ”默认 额外 说 明 
int(4) 二 auto_increment ”自动 编号 这 
name varchar(13) gb2312_chinese_ci 是 NULL 管理 员 名 
varchart50) gb2312_chinese_ci 是 NULL 管理 员 密 码 


pwd 


图 421 管理 员 表 


户 信息 表 ) 


户 的 基础 信息 。 该 数据 表 结 构 如 图 4.22 所 示 。 


第 4 章 ”电子 商务 平台 网 (Apache+PHP+phpMyAdmin+MySQL 5.0 实现 ) 


加 服务 器 : localhost >” 剖 数据库: db_shop ， 国 表 :tb_user 


字段 类 型 整理 Null ”默认 额外 说 明 
这 int( 和 证 auto_increment ”自动 编号 这 
name varchart25) ”gb2312_chinese_ci 是 NULL 用 户 名 
pwd Yarchar(50) ”gb2312_chinese_ci 是 NULL 用 户 密码 
dongjie int(d) 是 NULL 标记 用 户 是 否 被 志 结 
email varchar(25) ”gb2312_chinese_ci 是 NULL 用 户 E-mail 也 址 
sfzh varchar(25) yb2312_chinese_ci 是 NULL 用 户 身 供 证 号 
tel varchar(25) ”gbh2312_chinese_ci 是 NULL 联系 电话 
tishi varchar(50) ”gb2312_chinese_ci 是 NULL 密码 找 回 提示 
huida warchar(50) ”gb2312_chinese_ci 是 NULL 密码 找 回答 案 
dizhi varchart100) yb2312_chinese_ci 是 NULL 用 户 联 系 地 址 
youbian varchar(25) ”gb2312_chinese_ci 是 NULL 用 户 邮 编 
regtime varchar(25) ”gb2312_chinese_ci 是 NULL 用 户 注册 时 间 
truename varchar(25) ”gb2312_chinese_ci 是 NULL 用 户 真 实 姓 名 
pwd1 yarchar(50) ”gb2312_chinese_ci 是 NULL 未 加 密 的 用 户 密码 
qq varchar(25) gb2312_chinese_ci 是 NULL 用 户 QQ 号 码 


图 4.22 用 户 信息 表 结构 


(5) tb_leaveword (用户 留 言 表 ) 
用 户 留言 表 主要 用 于 存储 用 户 留言 的 相关 信息 。 该 数据 表 结 构 如 图 4.23 所 示 。 


加 服务 器 : localhost ， 咒 数据 库 : db_shop ， 国 表 :tb_leaveword 

字段 类 型 整理 Null ”默认 额外 说 明 
id intt4y 否 auto_increment ”自动 编号 记 
userid int(d) 是 NULL 用 户 这 
title yarchart100) gb2312_chinese_ci 是 NULL 留言 主题 
content text gb2312_chinese_ci 是 NULL 留言 时 间 
time Yarcharf25) gb2312_chinese_ci 是 NULL 留言 内 容 


图 4.23 用 户 留言 表 结构 
(6) tb_pingjia〈 商 品评 价 表 ) 
商品 评价 表 主 要 用 于 存储 用 户 对 商品 的 评论 信息 。 该 数据 表 结 构 如 图 4.24 所 示 。 
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加 服务 器 : localhost ， 轧 数据 库 : db_shop ， 国 表 : tb_pingjia 


字段 类 型 整理 Null -默认 额外 说 明 
这 int(4) 否 auto_increment ”自动 编号 计 
userid int(4) 是 NULL 用 户 这 
spid int(4) 是 NULL 商品 qd 
title varchar(100) gb2312_chinese_ci 是 NULL 评价 主题 
content text gb2312_chinese_ci 是 NULL 评价 内 容 
time varchar(25) gb2312_chinese_ci 是 NULL 评价 时 间 


图 4.24 商品 评价 表 结构 
[0 说 明 : 限于 篇 幅 ， 笔 者 在 此 只 给 出 较 重要 的 数据 表 ， 其 他 数据 表 参 见 本 书 附带 的 光盘 。 


4.5 公共 模块 设计 


4.5.1 数据 库 连接 文件 


这 里 进行 的 第 一 项 内 容 就 是 建立 与 数据 库 的 连接 文件 conn.php。 数 据 库 连 接 文件 在 以 后 的 其 他 动 
态 页 中 均 要 涉及 到 ， 所 以 笔者 把 涉及 到 的 脚本 文件 放 在 了 这 里 进行 重点 介绍 。 以 后 再 涉及 数据 库 连接 
文件 时 就 不 再 进行 效 述 了 。conn.php 文件 的 代码 如 下 : 

例 程 01 ”代码 位 置 ， 光盘 \TM\04\shop\conn\conn.php 


<?php 

[9 Slink=mysql_connect('localhost','root','root’); // 连 接 到 MySQL 服 务 器 

@ mysql_select_db('db_shop',$link); // 指 定 连 接 到 名 称 为 db_shop 的 数据 库 
> 

< 代码 贴 十 


@ mysql_conect0: 连接 MySQL 服务 器 ， 服 务 器 的 用 户 名 为 root， 密 码 为 root。 

@ mysql_select_db(): 用 于 连接 指定 的 MySQL 数据 库 。 

如 果 某 个 页 面 中 需要 进行 数据 库 的 操作 ， 在 页 面 的 前 台 直 接 包含 该 文件 即 可 ， 代 码 如 下 : 
<?php 


include ("conn/conn.php"); // 包 含 数据 库 文件 
> 


4.5.2 CSS 样式 表 文件 


CSS 是 Cascading Style Sheets( 层 县 样式 表单 ) 的 简称 ， 是 一 种 简单 、 灵 活 、 易 学 的 工具 ， 可 使 任 
何 浏览 器 都 听从 指令 、 知 道 该 如 何 显 示 元 素 及 其 内 容 。 人 掌握 CSS 样式 表 不 仅 能 更 好 、 更 快 地 完成 网 页 
设计 使 页 面具 有 动态 效果 ， 还 有 助 于 统一 网 站 的 整体 风格 。 

在 网 页 中 使 用 CSS 的 方法 如 下 : 


RS 
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回 ”把 CSS 文档 放 到 <head></head> 标 记 中 。 
<head><style type="text/css"> … </style> </head> 
把 CSS 样式 表 写 在 HTML 行内 ， 代 码 如 下 : 
<p style="“font-size: 14pt; color: blue”> 蓝 色 14 号 文字 </p> 
这 是 采用 <style=" "> 的 格式 把 样式 写 在 HTML 中 的 任意 行内 ， 这 种 方法 比较 方便 灵活 。 


把 编辑 好 的 CSS 文档 保存 成 扩展 名 为 “.CSS” 的 外 部 文件 , 然后 在 <head> 标 记 中 调用 该 文件 ， 


调用 方法 的 代码 如 下 : 
<head> <link rel=stylesheet type="text/css" href=".css 文档 的 相对 路 径 "> … </head> 
这 种 方式 能 使 多 个 文档 同时 使 用 相同 的 样式 ， 从 而 能 够 减少 大 量 的 见 余 代码 。 
电子 商务 平台 采用 <link> 将 扩展 名 为 “.css” 的 外 部 文件 嵌入 到 网 页 中 ， 代 码 如 下 : 
<link href="css/font.css" rel="stylesheet"> 
电子 商务 平台 中 应 用 的 font.css 样式 表 文 件 的 代码 如 下 : 
例 程 02 ”代码 位 置 ， 光盘 \TM\04\ shop\ess\font.css 


<!-- 定 义 文字 链接 的 CSS 样 式 --> 
Ailink { 

COLOR: #006699; TEXT-DECORATION: none 
} 
Ai:visited { 

COLOR: #006699; TEXT-DECORATION: none 
} 
Ai:active { 

COLOR: #006699; TEXT-DECORATION: none 
有 


A:hover { 
COLOR: #000000 


} 

<!-- 定 义 网 页 背景 及 文字 颜色 --> 

BODY { 
background-image: url(../images/bg.gif); 
margin-top: Opx; 


》 
<!-- 定 义 表格 文字 的 打下 和 颜色 --> 
TD.TH { 

FONT-SIZE:12px; COLOR: #006699; 


! 

<!-- 定 义 按 扭 的 CSS 样 式 --> 

.buttoncss { 
font-family: "Tahoma", "宋体 "; 
font-size: 9pt; color: #003399; 
border: 1px #003399 solid; 
color:006699; 
BORDER-BOTTOM: #93bee? 1px solid; 
BORDER-LEFT: #93bee2 1px solid; 
BORDER-RIGHT: #93bee2 1px solid; 
BORDER-TOP: #93bee2 1px solid; 
background-color: #e8f4ff; 
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CURSOR: hand; 
font-style: normal ; 


} 
<!-- 定 义 输入 框 的 CSS 样 式 --> 
.inputcss { 
font-size: 9pt; 
color: #003399; 
font-family: "宋体 "; 
font-style: normal; 
border-color: #93BEE?2 #93BEE2 #93BEE2 #93BEE?2 ; 
border: 1px #93BEE?2 solid; 


} 
<!-- 定 义 无 边 框 的 输入 框 的 CSS 样 式 --> 
.inputcssnull { 

font-size: 9pt; 

color: #003399; 

font-family: "宋体 "; 

font-style: normal; 

border: Opx #93BEE2 solid; 


B 

<!-- 定 义 滚动 条 的 CSS 样 式 --> 

.scrollbar{ 
SCROLLBAR-FACE-COLOR: #FFDD22; 
FONT-SIZE: pt; 
SCROLLBAR-HIGHLIGHT-COLOR: #69BC2C; 
SCROLLBAR-SHADOW-COLOR: #69BC2C; 
SCROLLBAR-3DLIGHT-COLOR: #69BC2C; 
SCROLLBAR-ARROW-COLOR: #ffffff 
SCROLLBAR-TRACK-COLOR: #69BC2C; 
SCROLLBAR-DARKSHADOW-COLOR: #69BC2C 


4.6 前 人 台 首 页 设计 


在 无 数 个 相互 竞争 的 网 页 中 ， 特 别 是 对 电子 商务 网 站 来 说 ， 首 页 极为 重要 ， 它 必须 展现 网 站 的 特 
性 ， 并 积极 的 加 以 表现 ， 首 页 设计 的 好 坏 将 直接 操纵 顾客 的 购买 欲望 和 情绪 。 在 电子 商城 的 首页 设计 
中 ， 首 先 必须 把 商城 推出 的 最 新 商品 、 推 荐 商品 、 热 门 商 品 、 最 新 公告 等 商城 的 特色 和 动态 信息 展现 
给 顾客 ， 然 后 再 提供 查看 订单 、 购 物 车 、 商 品 分 类 查询 等 业务 。 


4.6.1 前 台 首 页 概述 


网 站 首页 是 关于 网 站 的 建设 及 形象 宣传 ， 它 对 网 站 生存 和 发 展 起 着 非常 重要 的 作用 。 首 页 设计 的 
好 坏 将 直接 影响 到 顾客 的 购买 欲望 ， 同 时 ， 首 页 也 是 一 个 信息 含量 较 高 ， 内 容 丰 富 的 宣传 平台 ， 用 户 
不 但 可 以 在 第 一 时 间 内 掌握 商城 最 新 商品 、 热 门 商品 、 推 荐 商品 ， 还 可 以 实现 商品 商品 搜索 、 订 单 查 
询 等 功能 。 电 子 商 务 平台 前 台 首 页 主要 包含 以 下 内 容 

回 ”网 站 菜单 导航 : 主要 包括 最 新 商品 、 推 荐 商品 、 热 门 商品 、 商 品 分 类 、 用 户 中心 、 订 单 查询 、 


我 的 购物 车 。 
Sa 
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回 ”最 新 商品 模块 : 

回 ”推荐 商品 模块 : 

回 热门 商品 模块 : 

回 会员 登录 模块 : 
情况 。 

回 用 户 中 心 模块 : 
和 评论 信息 。 


回 ”站 内 公告 模块 : 
回 ”友情 链接 模块 : 


电子 商务 平台 前 台 首 页 分 为 网 站 导航 、 


商品 信息 的 快速 搜索 及 高 级 搜索 引擎 。 


主要 按时 间 先 后 顺序 展示 最 新 商品 及 详细 信息 查看 。 


主要 展示 商城 重点 推荐 的 商品 及 详细 信息 查看 。 


主要 
主要 用 


主要 用 于 在 用 户 登 录 后 ， 对 个 人 资料 的 修改 、 对 登录 密 


主要 用 于 发 布 网 站 提供 部 分 商品 信息 以 及 购买 商品 的 优惠 制度 等 信息 。 


主要 用 


于 展示 销量 最 高 的 商品 及 详细 信息 查看 。 
-会 员 登录 ， 登 录 后 可 以 购买 商品 、 


于 企业 链接 的 广告 信息 。 


版 权 信息 、 左 分 栏 、 


查询 提交 的 订单 、 查 看 个 人 消费 


码 的 修改 、 用 户 留言 


内 容 分 栏 4 个 部 分 。 下 面 看 一 下 本 案 


例 中 提供 的 商城 前 台 首 页 ， 该 首页 在 本 书 光盘 中 的 路 径 为 \TM\04\shop\index.php， 如 图 4.25 所 示 。 


用 户 : mr 
TH: 00000 
验证 : 2058 

提交 | 注册 


2058 
找 回 密码 


RAY 二 pacad GD 


+ 程序 正在 测试 中 


+ sp 相左 侧 分 栏 


本 商城 从 即日 起 推出 忧 囊 活 


5 + 一 路 有 你 + 网 站 商城 
9 一 生 LOVE4++ 购 物 中 心 
口 第 五 季 ey4 购 物 中 心 


请 输入 产品 名 称 : 


剩余 数量 : 2 


查看 详情 到 


市 场 价 : 
会 员 价 : 
剩余 数量 : 1600 


网 站 导航 、LOGO、 搜 索引 擎 


,9 


和 


查看 详情 科 多 六 


图 4.25 电子 商务 平台 前 台 首 页 


话 动 详情 » 


Commend Product 更 多 … 


市 场 价 : 
会 员 价 : 189 


各 余数 量 ; 5000 


查看 详情 野史 工 


市 场 价 : 
会 员 价 : 


条 余数 量 : 6000 


会 员 价 : 258 
齐全 数量 : 20000 
EE 
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电子 商务 网 站 的 设计 是 展现 企业 形象 、 介 绍 商品 和 服务 、 体 现 企业 发 展 战略 的 重要 途径 ， 这 也 是 
开发 网 站 的 根本 目的 ， 因 此 必须 明确 用 户 的 需求 ， 从 而 做 出 切实 可 行 的 设计 计划 。 要 根据 消费 者 的 需 
求 、 市 场 的 状况 、 企 业 自 身 的 情况 等 进行 综合 分 析 ， 牢 记 以 “消费 者 〈customer) ”为 中 心 ， 而 不 是 以 
“美术 ”为 中 心 进行 设计 规划 。 不 同 的 产品 网 站 所 要 表达 的 信息 类 型 也 不 一 样 ， 要 用 适合 表达 其 产品 
特点 的 风格 和 色彩 的 设计 。 

电子 商务 平台 采用 二 分 栏 结构 布局 ， 页 面 简练 、 大 气 、 个 性 鲜明 等 特点 ， 从 而 体现 电子 商务 网 站 
的 特色 和 个 性 化 ， 示 意图 如 图 4.26 所 示 。 


top.php 


left php index php 


bottom php 


图 4.26 电子 商务 网 站 示意 图 
4.6.2 ”前 台 首 页 技术 分 析 


为 了 保证 页 面 的 整洁 和 增强 页 面 的 可 维护 性 ， 在 前 台 首页 面 中 使 用 引用 语句 来 包含 主要 的 功能 页 
面 ， 各 个 功能 模块 分 别 保存 在 单独 的 文件 中 。 这 样 做 的 目的 是 使 系统 具有 统一 的 风格 ， 并 且 如 果 对 某 
项 功能 进行 维护 ， 只 需要 修改 top.php、left.php、index.php 或 bottom.php 页 即 可 ， 不 需要 每 页 都 进行 改 
动 ， 这 样 可 以 很 大 程度 地 提高 网 站 开发 效率 ， 并 且 维 护 起 来 也 是 非常 方便 的 。 

在 PHP 页 面 中 包含 文件 有 4 种 方法 : 

应 用 include 语句 实现 。 

使 用 include() 语 句 包含 外 部 文件 时 ， 只 有 代码 执行 到 include 语句 时 才 将 外 部 文件 包含 进来 ， 当 所 
包含 的 外 部 文件 发 生 错 误 时 ， 系 统 只 给 出 一 个 警告 ， 而 整个 php 文件 则 继续 向 下 执行 。include 语句 的 
语法 如 下 : 

void include(string filename); 


参数 filename 是 指定 的 完整 路 径 文 件 名 。 


NE 
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全 注意 : 从 PHP 5.2 开始 ，include 语句 将 会 比 include_once 语句 执行 速度 快 ， 因 为 include 语句 可 以 
优化 脚本 ， 不 会 检查 包括 的 文件 或 函数 是 否 已 经 存在 。 

应 用 require 语句 实现 。 

require 语句 与 include 语句 类 似 ， 都 是 实现 对 外 部 文件 的 调用 。 当 使 用 require 语句 载 入 文件 时 ， 
它 会 作为 PHP 文件 的 一 部 分 被 执行 。 语 法 如 下 : 

void require(string filename); 

参数 filename 是 指定 的 完整 路 径 文 件 名 。 

下 面 应 用 require 语句 包含 并 运行 指定 的 外 部 文件 top.php， 代 码 如 下 : 

<?php require("top.php"); // 嵌 入 外 部 文件 top.php 页 ?> 

应 用 include_once 语句 实现 。 

应 用 include_once 语句 多 次 调用 相同 的 文件 时 ， 程 序 只 会 调用 一 次 。 例 如 ， 要 导入 的 文件 中 存在 
一 些 自 定义 函数 ， 那 么 如 果 在 同一 个 程序 中 重复 导入 这 个 文件 ， 在 第 二 次 导入 时 便 会 发 生 错 误 ， 因 为 
PHP 不 允许 相同 名 称 的 函数 被 重复 声明 第 二 次 。 语 法 如 下 : 

void include_once (string filename); 

filename 参数 是 指定 的 完整 路 径 文件 名 。 

下 面 应 用 include_once 语句 包含 并 运行 指定 的 外 部 文件 top.php， 代 码 如 下 : 

<?php include_once("top.php"); // 杠 入 外 部 文件 top.php 页 ?> 

应 用 require_once 语句 实现 。 

require_once 语句 是 require 语句 的 延伸 , 它 的 功能 与 require 语句 基本 类 似 , 不 同 的 是 , require_once 
语句 会 先 检查 要 导入 的 文件 是 不 是 已 经 在 该 程序 中 的 其 他 地 方 被 调用 过 ， 如 果 有 的 话 就 不 会 再 次 重复 
调用 该 文件 。 语 法 如 下 : 

void require_once (string filename); 

filename 参数 是 指定 的 完整 路 径 文件 名 。 
下 面 应 用 require_once 语句 包含 并 运行 指定 的 外 部 文件 top.php， 代 码 如 下 : 
<?php require_once("top.php"); 1/ 嵌入 外 部 文件 top.php 页 ?> 


4.6.3 前 台 首 页 的 实现 过 程 
国 前台 首页 使 用 的 数据 表 : tb_shangpin、tb_user、tb_gonggao、tb_links 


在 一 个 网 站 中 ， 前 台 首 页 被 访问 的 次 数 是 比较 多 的 。 为 了 加 快 页 面 的 运行 速度 、 提 高 访问 量 ， 本 
实例 前 台 首页 使 用 include 语句 包含 主要 功能 模块 ， 代 码 如 下 : 


4 


PHP 项 目 开发 全 程 实录 


例 程 03 ”代码 位 置 ， 光盘 \TM\04\ shop\index.php 


<table width="766" border="0" cellspacing="0" cellpadding="0"> 
<tr> 


[9 <?php include("top.php");?> 
</td> 
</t> 
<tr> 
<td width="209"> 
四 <?php include("left.php");?> 
</td> 
© <! 一 商品 展示 模块 的 代码 部 分 --> 
<td> 
/商品 展示 模块 代码 部 分 略 


<!-- 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 - -> 
<td colspan="2"> 
目 <2php include("bottom.php"); ?> 
</td> 
</tr> 
</table> 


Ah 代码 贴 十 
@ 应 用 include 语句 包含 top.php 文件 ， 该 文件 用 于 显示 网 站 导航 、 企 业 LOGO、 搜 索引 擎 及 当前 登录 的 会 员 名 称 。 
@ 应 用 include 语句 包含 leftphp 文件 ， 该 文件 用 于 显示 用 户 登录 、 商 城 公 告 及 友情 链接 信息 。 
目 在 前 台 首页 (index.php ) 中 ， 应 用 表格 布局 的 方式 展示 商品 信息 。 
@ 应 用 include 语句 包含 bottom.php 文件 ， 该 文件 用 于 显示 版 权 信息 。 


4.7 ”商品 展示 模块 设计 


本 系统 在 前 台 为 用 户 提供 了 不 同 的 商品 展示 方式 ， 从 而 便于 消费 者 了 解 市 场 行情 ， 能 够 使 消费 者 
有 目的 地 选 购 一 些 商 品 。 


4.7.1 商品 展示 模块 概述 


商品 展示 模块 属于 电子 商务 平台 的 子 页 ， 主 要 显示 电子 商务 平台 的 商品 信息 。 商 品 信息 主要 为 用 
户 提供 信息 资源 ， 是 用 户 购买 商品 的 主要 因素 ， 因 此 商品 展示 模块 对 电子 商务 平台 来 说 尤为 重要 。 商 
品 展示 模块 主要 实现 以 下 功能 : 

商品 的 分 类 信息 展示 。 

分 页 显示 相应 类 别 的 商品 信息 。 
“214 。 
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用 户 可 直接 进行 商品 的 购买 。 
显示 重点 推荐 商品 、 最 新 商品 及 热门 商品 信息 。 


4.7.2 商品 展示 模块 技术 分 析 


在 电子 商务 平台 中 ， 考 虑 到 商品 的 种 类 会 非常 多 ， 因 此 采取 分 页 的 方式 进行 显示 。 本 购物 系统 中 

很 多 模块 多 采用 了 这 种 技术 。 读 者 只 要 熟悉 商品 分 类 模块 的 分 页 实现 方法 就 可 以 将 该 方法 应 用 到 它 处 ， 
单 击 商品 分 类 超级 链接 ， 即 可 以 分 页 的 形式 查看 该 类 别 下 所 有 商品 的 详细 信息 ， 代 码 如 下 : 
例 程 04 ”代码 位 置 : 光盘 \TM\04\shop\showfenlei.php 


<?php 
$sql=mysql query("select count(*) as total from tb shangpin where typeid='".$Sid."' order by addtime desc ",$conn); 
$info=mysql_fetch_array($sqD); /检索 指定 商品 类 别 下 的 所 有 商品 信息 
$total=$info[total]; /计算 该 类 别 下 所 有 商品 的 总 和 
这 $total 一 0) { // 如 果 商 品 总 和 为 0， 则 说 明 该 类 暂 无 商品 ， 给 出 相关 提示 
echo "<div align='center> 本 站 暂 无 该 类 产品 !</div>"; 
} 
else { // 否 则 ， 以 分 页 形式 输出 商品 信息 
Spagesize=3; // 每 页 显示 3 条 商品 信息 
if ($total<=$pagesize){ /如 果 商 品 总 数 小 于 每 页 最 多 显示 的 页 数 则 总 页 数 应 为 1 
S$pagecount=1; 


} 
/如 果 总 商品 数 不 能 整除 每 页 最 多 显示 的 商品 数 ， 则 总 页 数 应 该 比 两 者 整除 之 商 多 1 
if(Stotal%Spagesize)!=0)f 

S$pagecount=intval($total/$pagesize)+ 1; 


jelse{ /如 果 总 商品 数 能 整除 每 页 最 多 显示 的 商品 数 ， 则 总 页 数 应 为 两 者 之 商 
$pagecount=$total/$pagesize; 

if(($_GETIpage])=="")!{ // 如 果 $_GET[page] 的 值 为 空 ， 则 使 默认 显示 的 页 为 第 一 页 
Spage=1; 

}else{ // 否 则 ， 使 当前 显示 的 页 码 为 获取 的 $page 的 值 


$page=intval($ GET[page]); 
b 
$sqll=mysql query("select * from tb shangpin where typeid=".S$id." order by addtime desc limit 
"(Spage-1)*$pagesize.",Spagesize ",$conn); // 实 现 分 页 显示 
while($infol=mysql_fetch_array($sql1)) { // 应 用 while 循 环 语句 输出 商品 的 详细 信息 
> 
加 /商品 详细 信息 展示 的 代码 略 
<table width="550" height="25" border="0" align="center" cellpadding="0" cellspacing="0"> 
<t> 
<td><div align="right"> &nbsp; 本 站 共有 该 类 商品 &nbsp; 
<2php 
echo Stotal; /输出 该 类 别 下 的 商品 总 数量 


2> 
&nbsp; 件 &nbsp;: 每 页 显示 &nbsp;<?php echo $pagesize;?>&nbsp; 件 &nbsp; 第 &nbsp;<?php echo $page;?>&nbsp; 页 / 共 


&nbsp;<?php echo $pagecount; ?>&nbsp; 页 
*215 。 乡 
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<?php 
if($page>=2){ // 如 果 当 前 页 码 大 于 等 于 2， 则 显示 首页 及 前 一 页 链接 
?> 
© <a href="showfenlei.php?id=<?php echo $id;?>&page=1" title=" 首 页 "><font face="webdings"> 9 </font></a> 
四 <a href="showfenlei.php?id=<?php echo $id;?>&page=<?php echo $page-1;?>" title=" 前 一 页 "><font 
face="webdings"> 7 </font></a> 
<2php 
) 
if($pagecount<=4){ // 如 果 总 页 数 小 于 或 等 于 4， 则 显示 所 有 页 的 链接 
for($i=1;$i<=$pagecount; $i++){ 
> 
<a href="showfenlei.php?id=<?php echo $id;?>&page=<?php echo $i;?>"><?php echo $i;?></a> 
<?php 
} 
yelse{ // 如 果 总 页 数 大 于 4， 则 只 显示 前 4 页 链接 ， 并 显示 尾 页 和 后 一 页 链接 
for($i=1;$i<=4;$i++H){f 
> 
<a href="showfenlei.php?id=<?php echo $id;?>&page=<?php echo $i;?>"><?php echo $1;?></a> 
<?php }?> 
© <a href="showfenlei.php?id=<?php echo $id;?>&page=<?php echo $page-1;?>" title=" 后 一 页 "><font 
face="webdings"> 8 </font></a> 
@ <a href="showfenlei.php?id=<?php echo $id;?>&page=<?php echo $pagecount;?>" title=" 尾 页 "><font 
face="webdings"> : </font></a> 
<?php 
} 
?> 
Ah 代码 由 二 


@ <font face="webdings"> 9 </font>: 输出 “首页 ”文字 标识 M 。 
@ <font face="webdings"> 7 </font>: 输出 “前 一 页 ”文字 标识 44。 
@ <font face="webdings"> 8 </font>: 输出 “下 一 页 ”文字 标识 串 。 
@ <font face="webdings"> : </font>: 输出 “ 尾 页 ”文字 标识 串 。 


技巧 :为 了 加 强 网 页 的 可 操作 性 ， 商 品 展示 页 面 实现 了 分 页 功能 ， 并 通过 设计 文字 的 特殊 字体 
webdings 输出 首页 、 前 一 页 、 下 一 页 、 尾 页 的 图 标 (在 指定 的 标准 页 范围 显示 ， 详 见 代 码 
注释 ) 。 


4.7.3 商品 分 类 展示 的 实现 过 程 


国 ”商品 分 类 模块 使 用 的 数据 表 : tb_shangpin、tb type 

在 电子 商务 平台 首页 中 ,设置 商品 分 类 展示 不 仅 可 使 电子 商务 平台 的 所 有 商品 分 门 别 类 地 显示 出 
来 ， 而 且 为 用 户 选择 商品 提供 了 很 大 的 方便 。 

在 网 站 功能 导航 栏 中 单 击 “ 商 品 分 类 ”超级 链接 ， 进 入 到 商品 分 类 展示 页 面 。 在 该 页 面 中 系统 自 
动 检索 出 所 有 的 商品 分 类 超级 链接 ， 单 击 “ 家 居 日 用 ”超级 链接 ， 将 输出 该 类 别 下 的 所 有 商品 信息 ， 


Se 
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运行 结果 如 图 4.27 所 示 。 
购物 抽 坟 科 
好 多 抱 回 家 1 
人 
用 话 动 详情 » 
mm 计算 机 图 书 玩具 类 网 络 游戏 服饰 家 居 日 用 电影 
Bk 本 类 商 品 > 家 居 日 用 
RP 站 2 称 : 全 8 动机 
密码 ; 商品 品牌 : X44 商品 型 号 : 301X 
验证 : 8494 > 商品 简介 : ”无 
提交 | 注册 找 回 密码 @ 上 市 日 期 : 。 2005-7-8 剩余 数量 ; 8000 商品 等 级 ; 一 般 
商场 价 : 。 1600 元 会 员 价 : 1699 元 折扣 :95% 
| ep me CC 
商品 名 称 : ”水 杯 
* 程序 正在 测试 中 商品 品牌 : 44 商品 型 号 : 44 
+ 商城 的 价格 已 经 打响 [= 商品 简介 : 无 
+ 本 商城 从 即日 起 推出 忧 囊 活 上 市 日 期 : 。 1995-1-1 剩余 数量 : 1800 商品 等 级 : 精品 
， 所 有 会 员 商品 一 律 75 折 其 喜 到 商场 价 : 。 10o 元 会 员 价 : 96 元 折扣 : 。 96% 
* 电子 商务 系统 全 面 推出 酬谢 ..，| ------------------- 


图 4.27 商品 分 类 展示 页 面 的 运行 结果 
首先 建立 一 个 单独 的 tb_type 表 用 来 存储 商品 大 类 ， 然 后 通过 do…while 循环 语句 把 这 些 记录 的 
typename 字段 〈 商 品类 别名 称 ) 都 显示 出 来 ， 并 且 每 个 商品 类 别名 称 都 设 有 超 链接 ， 单 击 该 超 链接 用 
户 可 以 查看 该 类 别 下 所 有 商品 的 详细 信息 ， 代 码 如 下 : 


例 程 05 ”代码 位 置 ， 光盘 \TM\04\shop\showfenlei.php 


<?php 
$sql=mysql query("select * from tb type order by id desc",$conn); 
0 S$info=mysql_fetch_object($sql); // 查 询 商品 类 别 信息 表 中 的 信息 
if($info—false){ // 如 果 查 询 结 果 为 假 ， 则 弹出 相关 的 提示 信息 
echo "本 站 暂 无 商品 "; 
上 
else { // 否 则 ， 输 出 商品 类 别 信 息 
dof /应 用 循环 语句 为 商品 类 别名 称 添加 超级 链接 
@ echo "<a href='showfenlei.php?id=". $info->id.">".Sinfo->typename."&nbsp;</a>"; 
}while(Sinfo=mysql fetch_object($sqD)); 
b 
> 
< 代码 贴 二 


@ mysql_fetch_object: 从 结果 集中 获取 一 行 作为 对 象 ， 如 果 没 有 更 多 行 则 返回 false。 
@ $info->typename: 从 结果 集中 获取 商品 类 型 名 称 。 


27. 


PHP 项 目 开发 全 程 实录 


4.7.4 最 新 商品 展示 的 实现 过 程 


国 。 最 新 商品 模块 使 用 的 数据 表 : tb _shangpin 
在 网 站 功能 导航 栏 中 单 击 “ 最 新 商品 ” 超 链接 ， 进 入 到 最 新 商品 展示 页 面 。 在 该 页 面 中 系统 显示 
按 管 理 员 发 布 商品 的 时 间 降 序 排列 的 前 4 件 商品 ， 运 行 结果 如 图 4.28 所 示 。 


nr 邮 的 回 家 


话 动 详情 ， 
pra a 
pr ” New Produ 
| > 一 商品 名 称 : 数码 相机 
| > 商品 曲牌 : 时尚 商品 型 号 : X-s00 
ES 2007 | 商品 简介 : 引领 时 尚 的 数码 科技 
提交 | 注册 找 回 密码 上 市 日 期 2008-5-5 剩余 数量 : 20000 商品 等 级 : 精品 
商场 价 : ”2699 元 会 员 价 : 2599 元 折扣 : 97% 
| A pe GD a 本 加 Ri 
,程序 正在 测试 中 商品 名 称 : 。 全 自动 洗衣 机 
品 品牌 :  X 品 型 号 : 3 
， 商城 的 价格 已 经 打 咯 = pp WS 
本 调 城 人 即日 起 推出 忧 囊 活 @ 上 市 日 期 。 2005-7-8 剩余 数量 : 8000 商品 等 级 : 一 般 
* 所 有 会 员 商 品 一 律 75 折 忧 囊 商场 价 : 。 “1800 元 会 员 价 : 1699 元 折扣 :95% 
+ 电子 商务 系统 全 面 推出 研 谢 本 风 
图 4.28 最 新 商品 展示 页 面 的 运行 结果 
在 商品 信息 表 tb_shangpin 中 开辟 一 个 addtime 字段 ， 应 用 该 字段 记录 商品 的 添加 时 间 ， 在 前 台 显 
示 商 品 时 只 需 应 用 这 个 字段 将 所 有 商品 降序 排列 , 然后 应 用 do…while 循环 语句 将 排 好 序 的 记录 中 的 前 


4 条 记录 输出 到 浏览 器 ， 代 码 如 下 : 
例 程 06 ”代码 位 置 : 光盘 \TM\04\ shop\ shownew.php 


<?php 
$sql=mysql_query("select * from tb_shangpin order by addtime desc limit 0,4",$conn); // 查 询 最 新 的 4 件 商品 
S$info=mysql_fetch_array($sql); 


if($info—false){ // 如 果 S$info 的 值 为 空 ， 则 说 明 商 品 表 中 无 商品 
echo "本 站 暂 无 最 新 产品 !"; 
} 
else{ /如 果 $info 的 值 不 为 室 ， 显 示 所 有 商品 信息 
dof /应 用 do…while 循 环 语句 显示 所 有 的 商品 信息 
< 
<tr> 
<td width="89" rowspan="6"><div align="center"> 
<?php 
if($infoftupian]==""){ /如 果 图 片 为 室 ， 则 给 出 相应 的 提示 信息 


echo " 暂 无 图 片 "; 


Re 
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elsef /否则 ， 输 出 图 片 信息 
?> 
<a href="lookinfo.php?id=<?php echo Sinfo[id];?>"> <img border="0" src="<?php echo Sinfo[tupian];?>" 
width="80" height="80"></a> 
<?php 
} 
> 
</div></td> 
<td width="93" height="20"><div align="center" style="color: #000000"> 商 品名 称 : </div></td> 
<td colspan="5"><div align="left"><a href="lookinfo.php?id=<?php echo $info[id];?>"><?php echo 
S$info[mingcheng];?></a></div></td> 
<t> 
罗 /商品 详细 信息 部 分 代码 略 
<?php 
}while(Sinfo=mysql_fetch_array($sqD); 
} 
> 


全 注意; 在 do…while 循环 语句 中 ，while 后 的 分 号 不 能 省 略 。 
4.7.5 查看 商品 详细 信息 的 实现 过 程 


国 ”查看 商品 详细 信息 模块 使 用 的 数据 表 : tb_shangpin 

为 了 能 让 客户 全 面 了 解 某 件 商品 ， 本 购物 系统 设置 了 查看 商品 详细 信息 模块 。 在 网 站 首页 商品 展 
示 区 ， 单 击 相应 商品 中 的 “查看 详情 ”按钮 〈 或 在 商品 信息 展示 页 面 ， 单 击 相应 的 商品 名 称 超 链接 ) ， 
即 可 进入 到 “查看 商品 详细 信息 ”页 面 。 tis Mails 4.29 所 示 。 


购物 抽 夫 
“国生 


话 动 详情 » 


数码 相机 | 入 市 时 间 : 5-5 
用 户 : 2599 | 市场 从 ;|2699 
密码 : | | 国王 时 沿 
验证 : 4663 | | mrso | 小 量 : 20000 
提交 ] ; | | 
0 二 | “引领 时 尚 的 数码 科技 
mam | 
下 MA 二 pecard FT 


图 4.29 商品 详细 信息 展示 页 面 的 运行 结果 


和 0 说 明 : 在 该 模块 中 用 户 不 仅 可 以 全 面 了 解 商品 信息 ， 而 且 网 站 会 员 还 可 以 发 表 用 户 个 人 评论 ， 根 
据 用 户 的 评论 ， 管 理 人 员 可 以 对 商品 做 一 些 调整 ， 例 如 增加 一 些 口 碑 较 好 的 商品 ， 删 除 一 
些 评价 相对 较 差 的 商品 。 限 于 篇 幅 ， 用 户 评论 的 功能 本 章 不 做 重点 讲解 ， 详 细 代 码 请 读者 


参见 本 书 附 赠 光盘 。 
“219 g 
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在 网 站 首页 商品 展示 区 ， 添 加 “查看 详情 ”按钮 的 代码 如 下 : 
例 程 07 ”代码 位 置 ， 光盘 \TM\04\shop\index.php 
<a href="lookinfo.php?id=<?php echo $info[id];?>"><img src="images/xiangxi_btn.gif"' width="60" height="18" 
border="0"></a> 
单 击 相应 商品 中 的 “查看 详情 ”按钮 ， 提 交 商 品 id 到 数据 处 理 页 bookinfo.php 页 ， 通 过 GET 方法 
接收 提交 的 商品 的 id 值 , 然后 应 用 mysql_query0 函 数 检索 该 商品 id 所 对 应 的 商品 信息 , 最 后 在 设计 好 
的 表格 中 通过 echo0 语 句 输出 该 商品 的 详细 信息 。 代 码 如 下 : 
例 程 08 ”代码 位 置 ， 光盘 \TM\04\ shop\ lookinfo.php 


<?php 
include("conn/conn.php"); // 连 接 数 据 库 文件 
$sql=mysql_query("select * from th_shangpin where id=".$_GETI[id]."",Sconn); 
Sinfo=mysql_fetch_object(SsqD; /从 商品 表 中 获取 商品 信息 
?> 
<tr> 
<td width="89" height="80" rowspan="4" align="center" valign="middle" bgcolor="#FFFFFF"><div align="center"> 
<?php 
ifSinfo->tupian 一 ""){ // 如 果 该 商品 没有 有 图 片 ， 则 弹出 “ 暂 无 图 片 ” 
echo " 暂 无 图 片 "; 
} 
elsef /如 果 该 商品 有 图 片 ， 则 以 固定 尺寸 显示 
2> 


<a href="<?php echo Sinfo->tupian;?>" target="_blank"><img src="<?php echo Sinfo->tupian;?>" alt=" 查 看 大 图 " 
width="80" height="80" border="0"></a> 
<?php 
} 
> 
</div></td> 
<td width="92" height="20" align="left" bgcolor="#FFFFFF"> 商 品名 称 : ”</td> 
<td width="134" bgcolor="#FFFFFF"> &nbsp;<?php echo $info->mingcheng;?> </td> 
<td width="100" bgcolor="#FFFFFF"> 入 市 时 间 : </td> 
<td width="129" bgcolor="#FFFFFF">é&nbsp;<?php echo $info->addtime;?> </td> 
<t> 
3 // 部 分 商品 信息 显示 代码 略 
</table> 
说明: 单 击 图 片 超级 链接 ， 将 以 原始 尺寸 显示 图 片 资源 。 
4.7.6 单元 测试 


本 模块 主要 通过 商品 分 类 实现 商品 的 展示 ， 并 对 分 类 的 商品 进行 分 页 处 理 ， 以 此 达到 直观 显示 商 
品 信息 的 目的 。 在 对 商品 分 类 进行 调试 时 ， 出 现 如 图 4.30 和 图 4.31 所 示 的 现象 。 


> 
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购物 抽 龙 
好 随 当 抱 回 家 


计算 机 图 书 玩具 类 
Be 本 类 商品 >) 数 四 产品 
用 户 : 商品 名 称 : 。 守 话 革 院 
理 玛 : 商品 :时尚 LYE 两 型 号 : LIVE-o9 
验证 : 087 商品 简介 : 。 质 、 精 
提交 | 注册 找 回 客 码 上 市 日 期 : 2007-1-1 种 作 数 量 :99 商品 等 级 : 精品 
商场 价 : 。 sos 会 员 价 : 959s 元 0: sex 
上 A Paces em 四 


+ 南城 的 价格 已 避 打 啊 

* 本 商城 从 即日 起 推出 忧 喜 活 
* 所 有 会 员 商品 一 律 T5 折 忧 吉 
+ 电子 商务 系统 全 面 推出 天 


: 。 数码 相机 
:时尚 商品 型 号 : XN-5001 
4 对 尚 的 数码 科技 


一 生 Loygrrr 殉 物 中 必 
和 五 季 *y+ 购 物 中 心 


备 电脑 软件 


2843 
注册 找 回 密码 


提交 


息 ， 检 索 不 到 数据 


图 4.31 在 翻 页 时 检索 不 到 数据 


在 图 4.30 所 示 的 页 面 中 可 以 看 到 ， 该 类 的 商品 总 数 为 4 件 商品 ， 每 页 显示 3 件 商品 ， 因 此 ， 数 码 
产品 类 别 下 的 商品 应 为 两 页 进行 显示 , 而 在 单 击 “2” 超 级 链接 进行 分 页 时 , 却 弹出 如 图 4.31 所 示 的 “本 
站 暂 无 该 类 产品 ! ”。 按 逻辑 推理 ， 第 2 页 应 该 有 一 件 商品 ， 但 未 显示 。 

经 过 分 析 ， 在 进行 数据 查询 时 ， 是 按 商 品 的 分 类 进行 查询 的 ， 代 码 如 下 : 


$sqll=mysql_query("select * from tb_shangpin where typeid=".S$id." order by addtime desc limit 
".($page-1)*$pagesize.",$pagesize ",$conn); 


由 于 $id 的 值 没 有 获取 到 ， 所 以 在 翻 页 时 ， 系 统 检索 不 到 商品 信息 。 
解决 方法 : 


在 实现 各 个 分 页 数据 传 值 时 ， 将 分 类 商品 的 id 值 “id=<?php echo $id;?>” 也 一 并 传递 过 去 ， 代 码 


如 下 : 
。221 。 多 
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<a href="showfenlei.php?id=<?php echo Sid;?>&page=l" title=" 首 页 "> 

<a href="showfenlei.php?id=<?php echo $id;?>&page=<?php echo $page-1;?>" title=" 前 一 页 "> 
<a href="showfenlei.php?id=<?php echo $id;?>&page=<?php echo $page-1;?>" title=" 后 一 页 "> 
<a href="showfenlei.php?id=<?php echo $id;?>&page=<?php echo $pagecount:?>" title=" 尾 页 "> 


这 样 在 单 击 分 页 的 各 个 链接 后 ， 即 可 检索 到 分 类 商品 $id 的 值 ， 从 而 实现 了 商品 分 页 显示 功能 。 
上 说 明 : 商品 分 页 时 显示 的 分 页 文字 标识 ( 如 后 一 页 “小 ” ) 的 超 链接 ， 也 要 将 分 类 商品 的 id 什 
“id=<?php echo $id;?>” 也 一 并 传递 过 去 。 部 分 代码 如 下 : 
<a href="showfenlei.php?id=<?php echo Sid;?>&page=<2php echo $page-1;?>" title=" 后 一 页 "><font 


face="webdings"> 8 </font></a> <!-- 后 一 页 “小 ”文字 标识 超 链接 --> 
本 <! 一 省 略 其 他 3 个 文字 标识 超 链接 的 代码 部 分 --> 


4.8 购物 车 模块 设计 


4.8.1 网 站 购物 车 概述 


购物 车 在 电子 商务 平台 里 作为 前 台 用 户 端 程序 中 非常 关键 的 一 个 功能 模块 ， 帮 助 用 户 完成 商品 前 
选 购 ， 并 把 商品 交 给 服务 台 进行 结算 。 购 物 车 的 管理 框架 如 图 4.32 所 示 。 


购物 车 列表 


+ + + + 


消 宇 94 | | | 


查看 风 和 和 | | 移 除 购物 商品 | wai 


图 4.32 ”购物 车 管理 框架 


> 
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4.8.2 网 站 购物 车 技术 分 析 


在 电子 商务 平台 开发 过 程 中 ， 相 对 较 困 难 而 且 重 点 的 部 分 是 购物 车 的 实现 过 程 。 购 物 车 的 作用 是 
用 来 临时 储存 用 户 的 购物 信息 ， 用 户 可 以 修改 购物 车 中 的 商品 数量 、 移 除 购物 车 中 的 某 件 商品 、 清 空 
购物 车 等 功能 。 开 发 一 个 购物 车 的 方法 有 两 种 : 一 种 是 将 购物 信息 存储 到 数据 表 中 ; 另 一 种 是 将 购物 
信息 存储 到 Session 变量 中 。 

如 果 在 后 台数 据 库 中 单独 开辟 一 个 数据 表 来 存储 购物 车 中 的 内 容 ， 也 能 够 实现 购物 车 的 制作 ， 但 
这 会 大 大 浪费 数据 库 服务 器 的 硬盘 空间 ， 并 且 这 些 信息 对 用 户 和 管理 者 来 说 都 是 没有 价值 的 ， 毕 竞 购 
物 车 中 的 商品 不 是 用 户 确定 要 购买 的 商品 ， 所 以 购物 车 应 该 是 临时 存储 用 户 打算 购买 商品 的 地 方 ， 并 
且 购 物 车 中 的 商品 也 应 该 随 着 用 户 的 退出 而 清空 。 

考虑 到 以 上 因素 笔者 联想 到 Session， 购 物 车 的 实现 和 数据 存储 可 以 依赖 Session 实现 。 为 了 便于 
理解 ， 可 以 把 购物 车 和 和 超市 联想 起 来 。 首 先 应 该 为 每 位 光临 的 顾客 分 配 一 个 购物 车 ， 当 用 户 成 功 登 
录 后 , 为 用 户 分 配 一 个 $producelist 变量 和 一 个 $quatity 变量 , 分 别 用 来 存储 用 户 放 入 购物 车 中 商品 的 id 
和 该 商品 对 应 的 数量 ， 并 且 $producelist 初始 值 为 室 ， 而 变量 $quatity 初始 值 为 1。 

用 户 如 果 选 择 某 件 商品 并 打算 将 其 放 入 购物 车 中 ， 只 要 用 该 Sproducelist 变量 原来 的 值 加 上 新 放 入 
购物 车 中 的 id 值 再 加 上 字符 @, 同时 变量 $quatity 应 在 原来 的 基础 上 加 1 再 加 @, 这 样 就 能 实现 将 商品 
添加 到 购物 车 并 使 该 商品 初始 数量 为 1。 

如 果 用 户 打 算 修改 某 件 商品 的 数量 只 需 用 explode0 函 数 提取 该 商品 的 id 值 和 该 商品 此 时 的 数量 
值 ， 并 将 该 id 对 应 的 存储 在 变量 $quatity 中 的 该 商品 数量 赋 于 新 值 即 可 。 如 果 用 户 打算 将 购物 车 中 某 
件 商品 移 除 ， 只 需 将 该 商品 对 应 的 id 值 赋 于 空 值 ， 并 将 该 商品 对 应 的 数量 赋 于 空 值 。 清 空 购物 车 只 要 
将 变量 $producelist 和 变量 $quatity 同时 赋 于 空 串 即 可 。 


4.8.3 添加 至 购物 车 的 实现 过 程 


国 ”添加 至 购物 车 使 用 的 数据 表 : tb_shangpin 
在 网 站 商品 展示 区 ， 单 击 相应 商品 中 的 “购买 ”按钮 (或 在 商品 详细 信息 页 面 ， 单 击 “ 放 入 购物 
车 ” 超 链接 ) ， 即 可 进入 到 “添加 至 购物 车 ”页 面 。 添 加 至 购物 车 页 面 的 运行 结果 如 图 4.33 所 示 。 


可 本 


购物 抽 友 袖 、 
好 陋 轩 的 回 宗 ， 


话 动 详情 » 


用 户 : 


商品 名 称 ; 。 激 码 相机 
人 商品 名称: ”数码 相机 


104 和 商品 型 号 : JI-500 
验证 : \ 沿 的 数码 科技 


提交 | 注册 找 加 密码 惠 作 数量 : 2 商品 竺 级: 精品 
ee 会 员 价 : 2599 元 折扣 : 97% 
| A 千 necwu GD 二 


图 4.33 ”添加 至 购物 车 页 面 的 运行 结果 
。223 。 多 
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当 用 户 进入 商城 后 ， 一 旦 选 购 了 商品 ， 系 统 就 会 为 每 一 个 用 户 分 配 一 辆 购物 车 供用 户 使 用 ， 并 为 
每 个 用 户 分 配 两 个 session 变量 $producelist 和 S$quatity， 分 别 用 来 存储 用 户 放 入 购物 车 中 的 商品 id 和 这 
些 商品 的 数量 , 当然 一 个 变量 同一 时 刻 只 能 有 一 个 值 , 那么 如 何 将 多 个 id 值 同 时 保存 在 一 个 $producelist 
变量 中 呢 ? 首先 将 id 转变 成 字符 型 变量 ， 并 且 这 些 变量 用 字符 “@” 进 行 连接 ， 比 如 用 户 分 别 将 id 
为 1、3、5 的 商品 放 入 购物 车 中 ， 这 时 session 变量 $producelist 的 值 应 该 为 “1@3@5@”。 

当 用 户 不 断 单 击 商品 旁边 的 “购买 ”按钮 时 ， 系 统 将 会 不 停 地 帮 用 户 把 商品 放 入 到 给 用 户 分 配 的 
购物 车 中 。 对 于 相同 的 商品 ， 系 统 会 提示 用 户 已 经 添加 到 购物 车 中 ， 只 需 在 购物 车 中 修改 对 应 的 商品 
的 数量 即 可 。 添 加 至 购物 车 的 代码 如 下 : 

例 程 09 ”代码 位 置 : 光盘 \TM\04\shop\addgouwuche.php 


<?php 

session_start(); 

include("conn/conn.php"); /连接 数 据 库 文件 
if($_SESSION[username]=="") { // 判 断 用 户 是 否 已 经 登录 


echo "<script>alert( 请 先 登录 后 购物 !");history.back();</script>"; // 如 果 用 户 还 没 登录 ， 则 提示 用 户 先 登录 并 返回 
到 原来 页 面 
exit; // 用 exit 语 句 停止 循环 的 继续 执行 


} 
$id=strval($_GET[id]); // 获 取 商 品 id 值 
$sql=mysql query("select * from tb shangpin where id=".$id."",$conn); 
S$info=mysql fetch array($sql); 


if($info[shuliang]<=0) { // 如 果 商 品 数量 小 于 0， 则 提示 用 户 商 品 已 售 完 
echo "<script>alert(' 该 商品 已 经 售 完 !");history.back();</script>"; 
exit; 
| 
by $array=explode("(@",$_SESSION[producelist]); // 将 session 变 量 $producelist 中 的 内 容 用 字符 “@” 
进行 分 割 ， 并 将 结果 保存 在 数组 $array 中 
四 for($i=0:$i<count($array)-1;$i++)f 


if($array[$i]==$id) { // 如 果 $array 数 组 中 存在 与 $id 相 等 的 元 素 ， 说 明 该 $id 所 对 应 的 商品 已 经 在 购物 车 中 
echo "<script>alert(' 该 商品 已 经 在 您 的 购物 车 中 !"):;history.back(;</script>"; 
exit; 


} 


@ a SESSION[producelist].$id."@"; 
@ $_SESSION[quatity]=$_SESSION[quatity]."1@"; 

header("location:gouwul .php"); // 添 加 成 功 后 ， 重 新 定位 到 gouwul.php 页 面 显 示 购 物 车 中 的 内 容 

?> 
艺人 代码 贴 二 

@ explode(0) 函 数 : 以 字符 囊 $_SESSION[producelist] 中 的 子囊 @ 作 为 分 审 符 将 字符 囊 分 割 开 来 ,分割 后 的 一 个 或 多 
个 子囊 以 数组 的 形式 返回 。 

@ count0 函 数 : 用 来 计算 数组 $array 中 元 素 的 个 数 ， 如 果 变 量 为 空 则 返回 0; 变量 如 果 是 数组 ， 则 返回 数组 元 素 的 
个 数 ， 如 果 是 普通 型 变量 ， 则 返回 1。 

@$_SESSION[producelist]: 用 来 存储 用 户 放 入 购物 车 中 的 商品 id， 并 用 “@” 进 行 分 害 。 

@ $_SESSION[quatity]: 用 来 存储 用 户 放 入 购物 车 中 的 商品 数量 ， 并 用 “@” 进 行 分 害 ， 默 认 数量 设置 为 1。 


RS 
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[ED 说 明 : 上 面 说 到 的 id 指 的 是 tb_shangpin 表 中 的 id 字段 。 
4.8.4 查看 购物 车 的 实现 过 程 
国 查看 购物 车 使 用 的 数据 表 : tb_shangpin 
在 购物 的 过 程 中 ， 当 用 户 购买 完 商 品 或 单 击 “ 我 的 购物 车 ”超级 链接 后 ， 即 可 在 购物 车 列表 页 面 


查看 当前 用 户 的 所 购 商 品 的 详细 情况 ， 该 页 面 可 以 对 选 购 的 商品 进行 移 除 、 数 量 更 新 、 结 账 或 者 清空 
购物 车 等 操作 。 查 看 购物 车 页 面 的 运行 结果 如 图 4.34 所 示 。 


话 动 详情 
A .4 Cant 
用 户 : 商品 名 称 数量 。 “市场 价 折扣 操作 
密码 : 数码 相机 1 2699 元 97% 移 除 
验证 : Ci 水 杯 6 100 元 96 元 98% 移 除 
ea LT 去 收 良 各 清空 风物 车 


图 4.34 查看 购物 车 页 面 的 运行 结果 
在 查看 购物 车 页 面 中 ， 将 $producelist 用 @ 进 行 分 割 从 而 将 购物 车 中 现 有 商品 id 的 值 存放 到 数组 
$arraygwuc 中 ， 将 session 变量 $quatity 中 的 内 容 用 字符 @ 进 行 分 割 ， 并 将 结果 保存 在 数组 $arrayquatity 
中 ， 然 后 应 用 for 循环 语句 输出 购物 车 中 商品 。 代 码 如 下 : 
例 程 10 ”代码 位 置 ， 光盘 \TM\04\ shop\gouwul.php 


<?php 
session_start(); Jsession 变 量 初始 化 
@ ifs_SESSION[usernamel 一 ""){ // 如 果 用 户 名 为 空 ， 则 提示 用 户 先 登 录 
echo "<script>alert(' 请 先 登录 ， 后 购物 !"):history.back();</script>"; 
exit; // 如 果 用 户 没 登录 则 停止 程序 继续 执行 
} 
> 


<table width="500" border="0" align="center" cellpadding="0" cellspacing="1"> 
<form name="form]1" method="post" action="gouwul.php"> 


<?php 
session_register("total"); /注册 session 变 量 $total 用 来 保存 所 有 商品 价格 总 和 


/# 判 断 用 GET 方 法 提交 的 qk 的 值 为 yes， 则 将 producelist 和 $quatity 的 值 设 为 空 串 ， 从 而 实现 清空 购物 车 的 目的 所 
这 $ GET[qk]=="yes"){ 

$ SESSION[producelistl=""; 

$ SESSION[quatity]=""; 


/ 率 六 六 率 闪 这 六 六 六 六 率 闵 六 这 六 六 六 六 六 率 兴 闪 素 率 闵 六 闪闪 率 率 六 六 六 六 六 闲 六 这 六 六 六 率 闵 妆 率 率 率 率 率 闪闪 素 认 六 计 率 末 永 厅 闵 六 率 永 六 率 闵 率 闵 六 率 / 


// 将 $producelist 用 @ 进 行 分 割 从 而 将 购物 车 中 现 有 商品 id 的 值 存放 到 数组 Sarraygwuc 中 
225 乡 
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$arraygwc=explode("@",$ SESSION[producelist); 


$s=0; // 用 $s 保存 购物 车 中 商品 id 的 总 和 
for($i=0:$i<count($arraygwc):Si++){f 
四 $s+=intval($arraygwc[$i]); 
} 
这 $s 一 0 ){ /如 果 $s 的 值 为 室 ， 则 说 明 购物 车 中 无 商品 
echo "<tr>"; 
echo" <td height='25' colspan='6' bgcolor=#FFFFFF' align='center> 您 的 购物 车 为 空 !</td>"; 
echo"</tr>"; 
} 
else{ // 否 则 ， 显 示 购 物 车 中 的 所 有 商品 信息 
7> 
<tr> 
<td width="125" height="25" bgcolor="#FFFFFF"><div align="center"> 商 品名 称 </div></td> 
思 /显示 购物 标题 名 称 HTML 标 记 部 分 略 
</tr> 
<?php 
S$total=0; 


// 将 session 变 量 $producelist 中 的 内 容 用 字符 @ 进 行 分 割 ， 并 将 结果 保存 在 数组 $array 中 
Sarray=explode("(@",S$_SESSION[producelist]); 
// 将 session 变 量 $quatity 中 的 内 容 用 字符 @ 进 行 分 割 ， 并 将 结果 保存 在 数组 Sarrayquatity 中 
Sarrayquatity=explode("(@",S$_SESSION[quatity]); 
$_SESSION[quatity]=implode("@",$arrayquatity); 
for($i=0;$i<count($array)-1;$i++)! 
$id=$array[$i]; 
$num=$arrayquatity[$i]; 
/* 站 浊音 下 站 中 中 中 如 果 $id 不 为 空 ， 则 从 商品 信息 表 中 获取 指定 商品 id 的 信息 站 下定 
斌 $idl="){ 
$sql=mysql_query("select * from tb_shangpin where id=".$id.™",$conn); 
S$info=mysql fetch array($sql); 


S$totall =$num*$infofhuiyuanjia]; /商品 金额 = 选 购 数量 X 会 员 价 
S$total+=$totall; // 累 计 购 物 车 中 的 商品 金额 
$_SESSION["total"]=-$total; /购物 车 中 的 商品 的 的 累计 金额 
/本 半球 于 水 训 训 于 于 束 于 于 束 间 守 束 间 于 玉 间 于 弟 于 间 束 可 间 束 间 刘 束 间 守 束 浊 束 汪 间 于 间 守 于 半 于 浊 字 于 池 束 束 字 束 洒 池 囊 于 束 束 于 玫 玫 于 囊 于 于 于 于 于 半 半 于 。 / 
> 
站 显示 购物 商品 的 相关 信息 -一 一 > 
<t> 


<td height="25"><?php echo $info[mingcheng];?> </td> 

<td height="25"><input type="text" name="<?php echo $infofid];?>" size="2" class="inputcss" value=<?php echo 
$num;?>> </td> 

<td height="25" ><?php echo $info[shichangjia];?> 元 </td> 

<td height="25"><?php echo $info[huiyuanjia];?> 元 </td> 
© <td height="25"><?php echo (@(ceil(($infofhuiyuanjial/$info[shichangjia])*100))."%";?> </td> 

<td height="25"><?php echo $info[huiyuanjia]*$num." 元 ";?></td> 

<td height="25"><a href="removegwc.php?id=<?php echo Sinfo[id]?>"> 移 除 </a></td> 

</tr> 
< 


<?php 
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9 <td width="125"> 总 计 : <?php echo Stotal; ?> </td> 
</tr> 
</form> 
<?php 
b 


> 

</table> 
< 代码 贴 十 

@ $_SESSION[username]: 当 用 户 登录 网 站 后 ， 系 统 应 用 Session 变量 记录 用 户 名 。 只 有 会 员 可 以 有 操作 网 站 的 权 
限 ， 如 果 用 户 名 为 空 ， 则 提示 用 户 先 登录 。 

@ intval: 对 购物 车 中 的 商品 id 值 取 整 。 

@ ceil: 对 会 员 价 除 以 市 场 价 后 的 小 数 部 分 进 一 取 整 ， 如 相 除 后 的 结果 为 4.3， 应 用 ceil(4.3) 后 的 结果 为 5。 

@ $total: 购物 车 中 的 所 有 商品 的 的 累计 金额 。 


4.8.5 从 购物 车 中 移 去 指定 商品 的 实现 过 程 


国 ”从 购物 车 中 移 去 指定 商品 使 用 的 数据 表 : tb_shangpin 

添加 “ 移 除 ”文字 超 链 接 ， 删 除 id 指定 的 商品 信息 。 

<a href="removegwc.php?id=<?php echo $info[id]?>"> 移 除 </a> 

购物 车 的 作用 是 用 来 临时 储存 用 户 的 购物 信息 ， 因 此 用 户 可 以 随时 对 购物 车 中 的 商品 进行 移 除 。 
在 查看 购物 车 页 面 中 ， 单 击 对 应 商品 后 的 “ 移 除 ” 超 链接 ， 即 可 将 商品 信息 从 购物 车 中 删除 。 

该 功能 实现 的 基本 思想 是 : 首先 用 函数 explode() 将 session 变量 $producelist 以 @ 进 行 分 割 ， 并 把 分 
割 出 的 子 串 存放 到 数组 中 ， 然 后 将 用 户 打算 移 去 商品 对 应 的 数组 元 素 赋 于 空 值 ， 最 后 将 数组 元 素 重新 
组 合成 新 串 。 其 代码 如 下 : 

例 程 11 代码 位 置 : 光盘 \TM\04\shop\removegwc.php 


<?php 
session_start(); // 初 如 化 Session 变 量 
$id=$_GET[id]; 1/ 获取 用 户 打 算 移 去 商品 的 id 
$arraysp=explode("(@",$_SESSION[producelist]); /将 购物 车 中 的 商品 id 存储 到 数组 Sarraysp 中 
$arraysl=explode("@",$_SESSION[quatity]); /将 购物 车 中 的 商品 的 数量 存放 到 数组 $arraysl 中 
for($i=0;$i<count($arraysp); $i++) { 
if($arraysp[$i]—$id) { // 通 过 循环 寻找 与 id 值 相等 的 数组 元 素 
S$arraysp[Sil=""; 
Sarraysl[Si]=""; // 将 与 id 值 相等 的 数组 元 素 赋 于 空 值 


} 
$ SESSION[producelist]=implode("(@",$arraysp); 
$_SESSION[quatity]=implode("(@",$arrays]); // 应 用 implode() 函 数 将 数组 元 素 重新 组 合成 新 串 
header("location:gouwul .php"); // 重 新 定位 到 gouwul.php 显 示 购 物 车 中 的 商品 信息 
> 


A 
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6 技巧， 如 果 程序 中 应 用 到 了 session 变量 ， 那 么 就 需要 对 session 变量 进行 初始 化 ， 在 程序 的 首 行 
添加 “session_start();” 语 句 ， 如 果 没 有 对 session 变量 进行 初始 化 或 者 位 置 不 是 在 首 行 ， 那 
么 程序 在 运行 时 会 弹出 相应 的 错误 信息 。 


4.8.6 修改 商品 购买 数量 的 实现 过 程 


回 ”修改 商品 购买 数量 使 用 的 数据 表 : tb_shangpin 
购物 车 中 的 商品 默认 购买 数量 是 1 件 ， 如 果 用 户 打算 购买 多 件 相同 的 商品 就 需要 利用 修改 文本 框 
中 的 商品 数量 来 实现 。 修 改 商 品 数 量 与 从 购物 车 中 移 去 指定 商品 的 原理 类 似 ， 只 不 过 从 购物 车 中 移 去 
某 件 商品 是 将 该 商品 对 应 的 数组 元 素 赋 于 空 值 ， 而 修改 商品 购买 数量 是 将 购物 车 中 某 件 商品 对 应 的 数 
组 元 素 赋 于 新 值 。 其 代码 如 下 : 
例 程 12 ”代码 位 置 ， 光盘 \TM\04\ shop\gouwul.php 
@ while(list(Sname,Svalue)=each($_POST)) {  // 提 取 表 单 中 的 商品 id 和 新 数量 
for($i=0;$i<count($array)-1;$i++){ 
if(($array[$i])==$name) { 
© Sarrayquatity[Sil=Svalue; /获取 购物 车 中 每 种 商品 的 数量 ， 并 将 数量 保存 到 Sarrayquatity 数 组 中 
} 
} 
} 
Ah 代码 由 二 
@ list($name,$value)=each($_POST): 查看 购物 车 页 面 中 ， 输 入 商品 数量 的 文本 框 是 用 商品 id 来 命名 的 ， 所 以 此 处 
将 提交 表单 元 素 的 名 称 和 值 依 次 存储 到 对 应 的 变量 Sname 和 $value 中 。 
@ $arrayquatity[$i]=$value: 获取 购物 车 中 每 种 商品 的 新 数量 ， 并 将 新 数量 值 保存 到 $arrayquatity 数组 中 。 


4.8.7 ”清空 购物 车 的 实现 过 程 


在 查看 购物 车 页 面 添加 “清空 购物 车 ”文字 超 链接 ， 代 码 如 下 : 
<a href="gouwul.php?qk=yes"> 清 空 购物 车 </a> 
当 用 户 想 重 新 选 购 商品 时 ， 需 要 清空 购物 车 中 所 有 商品 ， 将 session 变量 $producelist 和 $quatity 的 
值 都 赋 于 空 串 。 其 代码 如 下 : 
例 程 13 ”代码 位 置 : 光盘 \TM\04\ shop\gouwul.php 


if($_GET[qk]=="yes"){ // 判 断 用 户 是 否 单 击 “ 清 空 购物 车 ” 超 链接 
$_SESSION[producelist]=""; /清空 购物 车 中 商品 id 
$_ SESSION[quatity]=""; /清空 购物 车 中 商品 数量 


RS 
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4.8.8 收银 台 结 账 的 实现 过 程 


国 ”收银 台 结账 使 用 的 数据 表 : tb_shangpin、tb_user、tb_dingdan 
当 用 户 选 购 完 商 品 后 ， 在 购物 车 列表 页 面 单 击 “ 去 收银 台 ” 超 级 链接 ， 即 可 进入 到 “收银 台 结 账 ” 
页 面 ， 运 行 结果 如 图 4.35 所 示 。 


收 货 人 姓名 : 蒜 臣 ts ” 反 可 
用 户 : - 
密码 : 邮政 编码 :|130000 
验证 : 998 联系 电话 :|0431-849786#+* 
提交 | 注册 找 回 密码 电子 邮箱 :|zixuant#@si# com 


详细 地 址 : ”| 吉林 省 长 春 市 河东 路 1+* 号 
NB 加 pscad oa | jiX7 式 : [ 变 RE 门 可 


+ 程序 正在 测试 中 7 式 : [两 E 支 和 ”到 

+ 商城 的 价格 已 经 打 明 保证 再 量 7 轻便 各 天 f 贷 到 前 10 妇 钟 打 电话 条 国 
;本 商城 从 即日 起 推出 优惠 活 简单 留言 : 

* 所 有 会 员 商品 一 律 75 折 优惠 到 
+ 电子 商务 系统 全 面 推出 一 放 


提交 订单 


图 4.35 收银 台 结账 页 面 的 运行 结果 

在 查看 购物 车 页 面 添加 “去 收银 台 ” 超 链接 ， 实 现 所 购买 商品 的 金额 结算 功能 ， 代 码 如 下 : 

<a href="gouwu2.php"> 去 收银 台 </a> 

单 击 “ 去 收银 台 ” 超 链接 ， 跳 转 到 gouwu2.php 页 ， 该 页 面 主 要 设计 用 户 需 要 填写 的 订单 结构 。 根 
据 用 户 在 购物 车 页 面 提交 的 商品 信息 ， 为 用 户 提供 填写 订单 的 平台 ， 然 后 将 用 户 选 购 的 商品 信息 〈 包 
括 商 品名 称 、 商 品 数量 等 ) 以 及 订单 信息 存储 在 数据 库 中 。 

收银 台 页 面 涉及 到 的 HTML 表单 的 重要 元 素 如 表 4.1 所 示 。 

表 4.1 收银 台 页 面 涉及 到 的 HTML 表单 的 重要 元 素 
名 称 | 元 素 类 型 重要 属性 含义 


method="post" action="savedd.php" onSubmit="retum 订单 表单 


forml | form . . 
chkinput(this)” 


<option selected value=" 普 通 平邮 "> 普通 平邮 </option> 
<option value=" 特 快 专递 "> 特快 专递 </option> 

shff select <option value=" 送 货 上 门 "> 送 货 上 门 </option> 商品 的 送 货 方式 
<option value=" 个 人 送 货 "> 个 人 送 货 </option> 


<option value="E-mail">E-mail</option>, 
。229 。 多 
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<option selected value=" 建 设 银行 汇款 "> 建设 银行 汇款 </option> 


<option value=" 交 通 银 行 汇款 "> 交通 银行 汇款 </option> 
-un i <option value=" 邮 局 汇款 "> 邮局 汇款 </option> 货款 的 支付 方式 
<option value=" 网 上 支付 "> 网 上 支付 </option> 


submit2 submit class="buttoncss" “提交 订单 ”按钮 


用 户 确定 要 购买 购物 车 中 所 有 商品 之 后 ， 就 需要 到 收银 台 页 面 填写 收 货 人 信息 ， 系 统管 理 人 员 将 
通过 该 信息 确定 收 货 人 地 址 、 商 品名 称 及 数量 等 ， 系 统 同 时 会 根据 这 些 信息 给 出 订单 。 具 体 实现 代码 
如 下 : 

例 程 14 ”代码 位 置 ， 光盘 \TM\04\shop\savedd.php 


<?php 
session_start(); /初始 化 session 变 量 
include("conn/conn.php"); // 连 接 数 据 库 文件 
$sql=mysql query("select * from tb user where name='".$ SESSION[usemame]."",$conn); 
S$info=mysql_fetch_array($sql); /检索 用 户 数据 表 中 的 信息 
$dingdanhao=date("YmjHis").Sinfofid]; /订单 号 = 当前 日 期 时 间 + 用 户 的 id 号 
$spc=$_ SESSION[producelist; /将 用 户 购 买 的 商品 名 称 串 赋 给 变量 $spc 
$slc=$_ SESSION[quatity]; // 将 用 户 购 买 的 商品 数量 串 赋 给 变量 $slc 
$shouhuoren=$_POST[name2]; /获取 收 货 人 姓名 
$sex=$_POST[sex]; 1/ 获取 收 货 人 性 别 
$dizhi=$_ POST[dz]; /获取 收 货 人 地 址 
S$youbian=$_POST[yb]; /获取 收 货 人 邮编 
S$tel=$_POST[tel]; /获取 收 货 人 电话 
Semail=$_POST[email]; 1/ 获取 收 货 人 E-mail 地 址 
$shff=$_POST[shff]; // 获 取 送 货 方式 
S$zfff-$_ POST[zfff]; /获取 支付 方式 
itrim($_POST[Iy]) 一 ""){ // 如 果 用 户 留言 为 空 
Sleaveword=""; / 则 将 $leaveword 变 量 设 为 空 
} 
else{ /否则 获取 用 户 的 留言 信息 
$leaveword=$ POSTIIy]; 

} 

$xiadanren=$_SESSION[usemame]; /获取 下 单 人 名 称 ， 即 当前 用 户 

Stime=date("Y-m-j H:i:s"); // 获 取 系统 当前 时 间 

$zt=" 未 作 任 何 处 理 "; 

S$total=$_SESSION[total]; /获取 购物 车 内 所 有 商品 的 累计 金额 


mysql query("insert into 
tb dingdan(dingdanhao,spc,slc,shouhuoren,sex,dizhi,youbian,tel,email,shff,zfff,leaveword,time,xiadanren,zt,total) values 
('$dingdanhao','$spe','$slc','$shouhuoren','$sex','$dizhi','$youbian','$tel','S$email','$shff,'$zfff,'$leaveword',' $time','$xiadanren','$z 


t,'$total)", $conn); // 将 信息 添加 到 tb_dingdan 表 
header("location:gouwu2.php?dingdanhao=Sdingdanhao"); 。“// 重 新 定位 到 收银 台 
> 


NS 
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技巧， 上 述 代码 中 mysql_query() 函 数 的 执行 结果 并 没有 具体 的 赋 给 某 个 变量 ， 这 是 因为 当 用 该 函 
数 执行 insert、delete 等 SQL 语 身 时 并 不 需要 回 显 结果 ， 而 执行 select 语句 时 一 般 都 需要 将 
结果 显示 在 前 台 页 面 中 ， 所 以 经 常会 将 该 函数 的 执行 结果 赋 给 菜 一 个 变量 ， 以 后 用 诸如 
mysql_fetch_array() 函 数 提 取 数 据 库 中 内 容 时 会 用 到 该 变量 。 


4.8.9 生成 商品 订单 的 实现 过 程 
国 ”生成 商品 订单 使 用 的 数据 表 : tb_shangpin、tb_dingdan 


在 收银 台 结账 页 面 ， 单 击 “ 提 交 订 单 ” 按 钮 ， 即 可 进入 “生产 商品 订单 ”页 面 。 该 页 面 的 运行 结 
果 如 图 4.36 所 示 。 


入 http://127.0.0.1 - 商品 订单 - Microsoft Internet Explorer 


蔡 喜 纯净 水 ， 您 已 成 功 的 提交 了 此 订单 :详细 信息 如 下 : 
订单 号 : 2007112214363739 
商品 列表 (各 下 ) : 
商品 名 称 小 计 
数码 相机 2599 
总 计 费 用 :2599| 


下 单 人 : 纯净 水 

收 货 人 : 紫 囊 

收 货 人 地 址 : 吉林 省 长 春 市 河东 路 lyy 号 

邮 编 : 130000 电 话 : 0431-84978xx#* 

E-mail zixuant#@si*. com 

送 货 方式 : 送 货 上 门 支付 方式 : 网 上 支付 

请 您 在 一 周 内 按 您 的 支付 方式 进行 汇款 , 汇款 时 注 明 您 的 订单 号 ! 汇 款 后 请 及 时 通知 我 们 
关闭 窗口 创 娃 时 间 ; 2007-11-22 14:36:37 


图 4.36 生成 商品 订单 页 面 的 运行 结果 


提交 表单 信息 到 数据 处 理 页 ， 将 商品 及 用 户 信息 存储 到 订单 信息 表 中 ， 添 加 成 功 后 将 生成 的 订单 
号 $dingdanhao 传递 到 收银 台 页 。 代 码 如 下 : 


例 程 15 ”代码 位 置 ， 光盘 \TM\04\shop\gouwu2.php 


<?php 

if($_GET[dingdanhao]!="") { // 如 果 订 单 号 不 为 空 
$dd=$_GET[dingdanhao]; /获取 订单 号 
session_start(); // 初 始 化 session 变 量 


// 以 子 串 @ 作 为 分 割 符 将 字符 串 分 割 开 来 ， 分 割 后 的 一 个 或 多 个 子 串 以 数组 的 形式 返回 
$array=explode("@",$ SESSION[producelist]); 


$sum=count($array)*20+260; /计算 窗 体 的 显示 高 度 

echo" <script language='javascript>"; /JavaScript 脚 本 标识 语句 开始 

echo" 
window.open('showdd.php?dd=+".$dd."",'newframe','top=1 50,left=200,width=600,height=".$sum.",menubar=no,toolbar=no,lo 
cation=no,scrollbars=no,status=no )"; // 在 新 窗口 showdd.php 页 中 输出 订单 信息 
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echo "</script>"; //JavaScript 脚 本 标识 语句 结束 
} 


人 
应 用 Window 对 和 象 的 open 方法 打开 一 个 新 窗口 showdd.php， 用 于 显示 商品 订单 的 详细 信息 ,将 商 
品 串 以 @ 子 串 进 行 分 割 ， 返 回 数组 $arraysp， 将 数量 串 以 @ 子 串 进行 分 割 ， 返 回 数组 $arrays1， 然 后 应 用 
for 循环 语句 循环 输出 订单 中 的 商品 信息 。 代 码 如 下 : 
例 程 16 ”代码 位 置 ， 光盘 \TM\04\shop\showdd.php 


<?php 
session_start(); // 初 始 化 session 变 量 
include("conn/conn.php"); // 连 接 数 据 库 文件 
$dingdanhao=$_GET[dd]; /获取 订单 号 
$sql=mysql query("select* from tb dingdan where dingdanhao= ".$dingdanhao."",$conn); 
$info=mysql_fetch_array($sql); // 查 询 订单 号 所 对 应 的 订单 详细 信息 
$spc=$info[spc]; /获取 商品 串 
$slc=$info[slc]; // 获 取 数 量 串 
$arraysp=explode("@",$spc); /将 商品 串 以 @ 子 串 进行 分 割 ， 返 回 数组 $arraysp 
Sarraysl=explode("@",$slc); // 将 数量 串 以 @ 子 串 进行 分 割 ， 返 回 数 组 $arraysl 
?> 


es /省 略 部 分 HTML 代 码 

<td height="20" bgcolor="#FFEDBF"><div align="center" class="style7"> 恭 喜 <?php echo $_SESSION[username];?>， 
您 已 成 功 的 提交 了 此 订单 ! 详 细 信 息 如 下 :</div></td> 

<td height="20" bgcolor="#FFFFFF"><div align="left"><span class="style5">&nbsp; 订 单 号 ; </span><?php echo 


$dingdanhao;?></div></td> 

<?php 

S$total=0; 

for($i=0;$i<count($arraysp)-1:$i++){ /用 for 循 环 语句 循环 输出 订单 中 的 商品 信息 

if($arraysp[$i]!=""){ /如 果 商 品 不 为 空 

$sqll=mysql query("select * from tb shangpin where id=".$arraysp[$i]."",$conn); 
Sinfol =mysql_fetch_array($sql1); /检索 指定 商品 的 详细 信息 
Stotal=$total+=$arraysl[$i]*$infol[huiyuanjia]; // 获 取 订 单 中 的 商品 总 计 费 用 

> 

ee 输出 订单 商品 的 详细 信息 -一 一 一 一 一 一 一- 3 


<tr bgcolor="#FFFFFF"> 
<td height="20"><div align="center"><2php echo $infol [mingcheng]:;?></div></td> 
<td height="20"><div align="center"><?php echo S$infol[shichangjial;?></div></td> 
<td height="20"><div align="center"><?php echo S$infol[huiyuanjial;?></div></td> 
<td height="20"><div align="center"><?php echo $arraysl[$1];?></div></td> 
<td height="20"><div align="center"><?php echo $arraysl[$i]*S$infol[huiyuanjial;?></div></td> 
</t> 
<?php 
上 


上 
> 


NE 


<tr bgcolor="#FFFFFF"> 
<td height="20" colspan="5"> 
<div align="right"><span class="style5"> 总 计 费 用 :</span><?php echo S$total;?> </div></td> 
</tr> 
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/订单 详细 信息 展示 部 分 代码 略 
4 
<?php 
$_SESSION[producelist]="":; // 清 空 购物 车 中 的 商品 串 
$_SESSION[quatity]=""; // 清 空 购物 车 中 的 数量 串 
> 


4.8.10 ”单元 测试 


在 开发 完 购物 车 模块 后 ， 为 了 保证 程序 正常 运行 ， 一 定 要 对 模块 进行 单元 测试 。 单 元 测试 在 程序 
开发 中 非常 重要 ,只 有 通过 单元 测试 才能 发 现 模块 中 的 不 足 之 处 ,才能 及 时 地 弥补 程序 中 出 现 的 错误 。 
在 开发 购物 车 模块 时 需 注意 : 在 购物 车 列表 页 面 更 改 商 品 数据 时 ， 小 计 金 额 与 统计 金额 没有 按 更 改 的 
数量 进行 计算 ， 如 图 4.37 所 示 。 


刻 Cart 


商品 名 称 数量 市 场 价 会 员 价 折扣 小 计 操作 


称 除 


清空 购物 车 总 计 : 9599 
更 改 商 品 的 购买 数量 ， 商 品 的 小 计 与 总 计 金 额 未 改变 


图 4.37 更 新 商品 数量 时 统计 数据 不 准确 


原因 : 

购物 车 中 用 于 输入 商品 数量 的 文本 框 是 用 商品 id 来 命名 的 ， 所 以 通过 语句 
list($name,$value)=each($_POST) 赋 值 就 使 sname 为 购物 车 中 某 件 商品 的 id， 而 $value 为 该 商品 对 应 的 

经 过 分 析 ， 从 数组 $array 中 取 值 时 ， 应 该 从 第 1 个 下 标 元 素 开始 取 值 ， 即 $array[0]， 而 $i 的 初始 值 
是 1， 说 明 数组 是 从 第 2 个 元 素 开始 取 值 的 ， 所 以 在 更 改 商 品 数量 时 ， 商 品 id 与 数量 对 应 不 上 ， 而 小 
计 及 总 计 金额 都 是 通过 数量 值 进行 计算 的 ， 由 于 数量 没有 获取 到 ， 所 以 程序 中 所 购 商 品 的 数据 统计 不 
准确 。 程 序 中 错误 的 代码 如 下 : 


<?php 

S$array=explode("(@",$_SESSION[producelist]); // 应 用 数组 存储 商品 串 

S$arrayquatity=explode("(@",$_SESSION[quatity]); // 应 用 数组 存储 商品 数量 串 
while(list($name,$value)=each($_POST){ // 提 取 表单 中 的 商品 id 和 新 数量 


“2. 


PHP 项 目 开发 全 程 实录 


for($i=1;$i<=count(Sarray);Sit+){ /应 用 for 循 环 语句 获取 商品 id 所 对 应 的 新 数量 
if(($array[$i])==$name){ // 如 果 商 品 的 id 与 更 新 的 数量 相等 
// 获 取 购 物 车 中 每 种 商品 的 数量 ， 并 将 数量 保存 到 $arrayquatity 数 组 中 
S$arrayquatity[$i]=$value; 
} 
} 
2> 
解决 方法 : 


应 用 for 循环 语句 将 数组 中 的 元 素 值 赋 于 新 的 商品 数量 ， 从 数组 $array 中 取 值 时 ， 应 该 从 第 1 个 下 
标 元 素 〈 即 数组 的 第 0 个 元 素 ) 开始 取 值 到 数组 的 最 大 下 标 -1 结束 ， 即 可 正确 统计 商品 的 小 计 与 总 计 
金额 。 更 改 后 的 代码 如 下 : 


<?php 


S$array=explode("(@",$_SESSION[producelist]); // 应 用 数组 存储 商品 串 
$arrayquatity=explode("@",$_SESSION[quatity]); // 应 用 数组 存储 商品 数量 串 
while(list($name,$value)=each($_POST))! /提取 表单 中 的 商品 id 和 新 数量 
for(Si=0;Si<=count(Sarray)-1;Si+H){ // 应 用 for 循 环 语句 获取 商品 id 所 对 应 的 新 数量 
if(($array[$1])==$name){ // 如 果 商 品 的 id 与 更 新 的 数量 相等 
// 获 取 购 物 车 中 每 种 商品 的 数量 ， 并 将 数量 保存 到 $arrayquatity 数 组 中 
Sarrayquatity[$1]=$value; 
} 


后 台 首页 承载 并 显示 网 站 后 台所 包含 的 模块 ， 使 网 站 管理 员 能 够 清楚 其 管理 权限 。 根 据 需 求 分 析 ， 
确定 电子 商务 平台 网 的 后 台 系统 包括 以 下 功能 模块 : 
商品 信息 管理 模块 : 主要 包括 商品 信息 的 添加 、 修 改 、 删 除 和 商品 类 别 的 添加 。 
用 户 信息 管理 模块 : 主要 包括 查询 和 显示 用 户 注册 信息 、 冻 结 用 户 、 用 户 留 言 管理 、 更 改 管 
理 员 密 码 。 
订单 信息 管理 模块 : 主要 包括 查看 所 有 用 户 提交 的 订单 信息 ， 并 根据 执行 阶段 对 订单 进行 标 
记 处 理 、 删 除 订 单 和 查询 订单 。 
公告 信息 管理 模块 : 主要 包括 站 内 公告 信息 的 添加 、 修 改 、 删 除 和 用 户 评论 信息 的 查看 和 
删除 。 
电子 商务 平台 网 的 后 台 首页 分 为 网 站 Banner 浮动 框架 、 导 航 浮动 框架 、 内 容 浮动 框架 3 个 部 分 。 下 
面 看 一 下 本 案例 中 提供 的 商城 后 台 首 页 ， 该 首页 在 本 书 光盘 中 的 路 径 为 \TM\04\shop\admin\default.php， 
如 图 4.38 所 示 。 
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菜 欣 记 子 商城 _ 


人 如 访 式 方式 品尝 人 者 
ER ES 
EEC 区 ES 
EE - GE 
ED EE 


9 两 加 商品 
a 

并 理 
5 二 加 商品 交 别 


用 P 首 时 i 时 ER ES 
“用户 全 息 各 征 EE EE E EL 
FE E 阿 上 于 


| 导航 浮动 棋 架 | En | | | 


iain | E 各 这 EE 
EE EE Ed | Es 
Er Er 内 容 浮动 框架 | 
ne | ES i 
E a Ee BBW 
Ei EE 
EE E Ea 
并 | 汉语 Ex 
Ee | ER 
| EE | 这 RE 区 
EN | | 区 
EDITIOEESEEEIITEEEEECTZEO 


als] ls ls) bals balls le bs be be ba) be ls) be fe) fe 


图 4.38 ”电子 商 务 平台 后 台 首 页 
4.9.2 ”后台 首页 技术 分 析 


在 网 站 后 台 管 理 系统 的 首页 面 中 使 用 浮动 框架 来 规划 页 面 布 局 。 浮 动 框架 的 作用 是 把 浏览 器 窗口 
划分 成 若干 个 区 域 ， 每 个 区 域内 可 以 显示 不 同 的 页 面 ， 并 且 各 个 页 面 之 间 不 会 受到 任何 影响 ， 为 框架 
内 每 个 页 面 命名 ， 作 为 彼此 互动 的 依据 。 

在 后 台 首 页 面 中 先 使 用 左右 浮动 框架 进行 页 面 布局 。 这 样 ， 就 可 以 在 页 面 顶端 设置 网 站 的 Banner， 
在 页 面 左 侧 设置 网 站 的 导航 功能 ， 在 页 面 的 右 侧 设置 后 台 系统 的 显示 主要 的 信息 内 容 。 

浮动 框架 <IFRAME> 是 一 种 特殊 的 框架 结构 ， 它 可 以 在 浏览 器 窗口 中 嵌 套 另外 的 网 页 文件 。 其 语 
法 格式 如 下 : 


<iframe src=" 文 件 " name=" 框 架 名 称 " align=" 对 齐 方式 " width=" 值 "” height-" 值 ”scrolling=" 值 ”frameborder=" 值 " 
marginwidth=" 值 " marginheight=" 值 "> 
</iframe> 


下 面 是 浮动 框架 属性 的 详细 讲解 。 

1. 浮动 框架 的 文件 路 径 属性 SRC 

语法 日 

<iframe src="file name"> 

file_ name: 表示 浮动 框架 文件 的 文件 名 或 者 其 他 超 链接 的 网 址 。 
2. 浮动 框架 的 名 称 属性 name 

语法 : 


<iframe src="file name" name="frame name"> 
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frame_name: 定义 的 浮动 框架 名 称 。 

浮动 框架 的 对 齐 属 性 align 

语法 

<iframe src="file name" align="left/center/right"> 

left: 居 左 对 齐 。 

center: 居中 对 齐 。 

right: 居 右 对 齐 。 

. 浮动 框架 的 宽度 和 高 度 属性 width、height 

语法 : 

<iframe src="file_name" width="value" height="value"> 

width: 浮动 框架 的 宽度 。 

height: 浮动 框架 的 高 度 。 

5. 浮动 框架 滚动 条 显示 属性 scrolling 

语法 : 

<iframe src="file_name" scrolling="value"> 

value 有 3 个 取 值 。 

yes: 显示 滚动 条 。 

no: 不 显示 滚动 条 。 

auto: 根据 窗口 内 容 决定 是 否 有 滚动 条 。 

6. 浮动 框架 边框 属性 frameborder 
语法 : 

<iframe src="file_name" frameborder="value"> 
value: 值 为 yes 代表 显示 框架 边框 ， 值 为 no 代表 隐藏 框 架 边 框 。 
7. 浮动 框架 边缘 的 宽度 和 高 度 属性 marginwidth、marginheight 
语法 : 

<iframe src="file name" marginwidth="value" marginheight="value"> 
marginwidth: 设 定 浮动 框架 左右 边缘 与 边框 的 宽度 。 
marginheight: 设 定 浮动 框架 上 下 边缘 与 边框 的 高 度 。 


上 


4.9.3 后 台 首 页 的 实现 过 程 


网 站 Banner 浮动 框架 的 代码 如 下 : 
例 程 17 代码 位 置 ， 光盘 \TM\04\shop\admin\default.php 
<IFRAME frameBorder=0 id=top name=top scrolling=no sre="top.php" 


style="HEIGHT: 90px; VISIBILITY: inherit WIDTH: 1003px; Z-INDEX: 3"> 
N * 230. 
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</IFRAME> 

导航 浮动 框架 的 代码 如 下 : 

例 程 18 ”代码 位 置 ， 光盘 \TM\04\shop\admin\default.php 
<IFRAME frameBorder=0 id=left name=left src="left.php" 


style="HEIGHT: 100%; VISIBILITY: inherit; WIDTH: 212px; Z-INDEX: 2"> 


</IFRAME> 

内 容 浮动 框架 的 代码 如 下 : 

例 程 19 代码 位 置 ， 光盘 \TM\04\shop\admin\default.php 

<IFRAME frameBorder=0 id=main name=main scrolling=yes src="lookdd.php" 


style="HEIGHT: 100%; VISIBILITY: inherit; WIDTH: 778px; Z-INDEX: 1"> 


</IFRAME> 


4.10 ”客户 订单 信息 管理 模块 设计 


系统 管理 员 是 根据 用 户 订单 来 发 放 货物 的 ， 因 此 客户 信息 管理 模块 在 电子 商务 平台 网 中 也 起 着 非 


党 重要 的 作用 ， 它 直接 影响 着 商家 的 信誉 和 消费 者 的 权益 。 


4.10.1 客户 订单 信息 管理 模块 概述 


客户 订单 信息 管理 模块 作为 后 台 核 心 的 功能 ， 主 要 用 于 执行 订单 已 收 款 、 已 发 货 、 已 收 货 的 过 程 ， 


把 订单 交 给 服务 器 进行 处 理 。 客 户 订单 信息 的 管理 框架 如 图 4.39 所 示 。 
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查找 客户 订单 
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是 否 删除 订单 
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图 4.39 客户 订单 信息 的 管理 框架 
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全 注意 : 为 了 商城 的 安全 ， 即 使 是 管理 员 ， 对 于 订单 的 管理 也 不 能 拥有 过 大 的 权限 ， 所 以 管理 员 只 可 
以 查看 订单 并 选择 订单 的 执行 状态 ， 而 不 允许 对 订单 信息 进行 修改 。 


4.10.2 客户 订单 信息 管理 模块 技术 分 析 


客户 订单 信息 管理 模块 的 核心 在 于 处 理 订单 及 打印 订单 ， 下 面 对 打 印 客户 订单 进行 技术 剖析 。 本 、 
模块 中 的 打印 订单 功能 主要 应 用 IE 内 置 的 WebBrowser 控件 实现 客户 订单 的 打印 等 功能 ， 该 控件 的 具 


体 参 数 如 下 : 


办 轨 


因 办 办 办 办 办 办 办 轨 


document.all.WebBrowser.Execwb(7,1): 
document.all.WebBrowser.Execwb(6,1): 
document.all.WebBrowser.Execwb(6,6): 
document.all. WebBrowser.Execwb(8,1): 
document.all.WebBrowser.Execwb(1,1): 
document.all.WebBrowser.Execwb(2,1): 
document.all.WebBrowser.Execwb(4,1): 
document.all.WebBrowser.Execwb(10,1): 查看 页 面 属 性 。 
document.all.WebBrowser.Execwb(17,1): 全 选 。 
document.all.WebBrowser.Execwb(22,1): 刷新 。 
document.all.WebBrowser.Execwb(45,1): 关闭 窗 体 无 提示 。 


表示 打印 预览 。 

表示 打印 。 

表示 直接 打印 。 
表示 页 面 设置 。 

打开 页 面 。 

关闭 所 有 打开 的 IE 窗口 。 
保存 网 页 。 


在 实现 打印 功能 时 ， 首 页 需要 建立 HTML 的 object 标签 ， 调 用 WebBrowser 控件 ， 代 码 如 下 : 


<object id=" WebBrowser" classid="CISID:8856F961-340A-11D0-A96B-00C04Fd705A2" width="0" height="0"> 


</object> 


建立 相关 的 打印 超级 链接 ， 并 调用 WebBrowser 控件 的 相应 参数 实现 打印 预览 、 打 印 、 直 接 打 印 、 


页 面 设置 等 常用 功能 。 其 代码 如 下 : 


<a href="#" onClick="document.all. WebBrowser.Execwb(7,1)"> 打 印 预览 </a> 
<a href="#" onClick="document.all. WebBrowser.Execwb(6,1)"> 打 印 </a> 

<a href="#" onClick="document.all. WebBrowser.Execwb(6,6)"> 直 接 打印 </a> 
<a href="#" onClick="document.all.WebBrowser.Execwb(8,1)"> 页 面 设置 </a> 


4.10.3 查看 客户 订单 信息 的 实现 过 程 


国 查看 客户 订单 信息 使 用 的 数据 表 : ”tb_dingdan 
管理 员 登 录 后 台 后 ,在 功能 导航 浮动 框架 中 单 击 “ 订 单 管 理 ”/“ 编 辑 订 单 ” 菜 单项 ， 即 可 进入 “ 查 
看 客户 订单 信息 ”页 面 。 该 页 面 的 的 运行 结果 如 图 4.40 所 示 。 
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人 


i 订 音 下 单 人 | 订 党 人 | 全 向 号 寺 |。 付 吉方 式 。 | 收 和 方式 订单 者 Ea 
ed 2007112215282339 | 纯净 水 | ”af4 ”| 1699 | 建设 和 款 | 普通 于 邮 | 未 作 任何 处 理 | 查看 | |[ 护 行 | 三 
be a007112215063959 | 师 廊 永 | ”3 | 2559 | 于 良 行乞 么 | 害 通 平邮 | 未 作 任何 外 十 | 查看 | | 的 行 | 品 
ee 2007112215115939 | 绩 净 水 | aaaad | 2599 | 建设 良 行 汇 和 | 着 通 闻 | ”未 作 任何 处 到 | 查看 | | 执行 | 三 
上 SHIZ2I4555739 | 到 水 | 荣 上 | 3559 | 同上 支付 | 让 芝 F 门 | 未 作 任何 由 大 | 查看 | [的 行 | 广 
Pe 2007112110305359 | 全 水 | watdf | S199 | 建设 让 行 江 区 | 交通 平 闻 | 已 K 束 已 发 信 已 收 从 | 查看 | [的 行 | 三 
0 用 户 信息 首 理 2007111915194439 | 统 让 水 | ”zs | 5199 | 建设 良和 汇 区 | 交通 部 | ”未 作 储 何 处 更。 | 查看 | [ 扩 行 | 三 
6。 用 户 留言 省 理 2007111506514459 | 统 让 水 | “145E | “196 | 建设 让 行 汇 识 | 交通 平 闻 | 已 权 各 已 发 从 已 收 黄 | 查看 | | 拟 行 | 万 
9 更 改 管理 员 信息 2007111415531039 | 纯净 水 | dadaa 8 | 建设 根 行 汇款 | 特快 专递 未 作 任何 处 理 查看 | | 执行 | 万 
2007111415421739 | 纯净 水 daad 784 | 建设 根 行 汇款 | 普通 平邮 已 发 货 查看 | | 执行 | 启 
A 2007111415360839 | 纯净 水 1 392 ”| 建设 根 行 汇款 | 首 通 平邮 已 发 货 查看 | | 执行 | 三 
0 山名 订单 20071114150302 | 红 信 水 | ”se ”| “555 | 建设 直行 江 区 | 邮 亿 专 过 EE 查看 | [执行 | 襄 
。 查询 订单 200711141523499 | 统 交 水 国宝 本 EEC 本 ET 区 本 查看 | | 执行 | 襄 
eae 200711115110559 | 统 让 水 | 汪 负 ”| “5256 | 建设 写生 入 区 | 旦 亿 专 过 区 于 查看 | [执行 | 襄 
Err 200711141511279 | 全 水 | 的 史 | 5195 | 建设 导 C 葡 | 这 蓉 上 站 区 查看 | | 执行 | 襄 
添加 公司 2007111414475139 | 纯净 水 同 呵 5198 ”| 交通 银行 汇款 | 特快 考 着 已 发 货 查看 | | 执行 | 品 
于 15 条 每 页 量 示 20 条 第 1 页] 区 了 页 | | 机 附和 拓 硕 

评论 首 理 


图 4.40 查看 客户 订单 信息 页 面 的 运行 结果 
当 用 户 提交 订单 后 ， 系 统管 理 员 就 可 以 通过 “订单 管理 ”模块 下 的 “编辑 订单 ”功能 查看 用 户 已 


例 程 20 ”代码 位 置 ， 光盘 \TM\04\ shop\admin\lookdd.php 
<table width="750" height="44" border="0" align="center" cellpadding="0" cellspacing="1"> 


<t> 


<td width="121" height="20" bgcolor="#FFFFFF"><divy align="center"> 订 单 号 </div></td> 
<! 一 省 略 部 分 关于 订单 标题 的 HTML 标 记 代码 -~ 
<td width="115" bgcolor="#FFFFFF"><div align="center"> 操 作 </div></td> 


</tr> 
<2php 


include("conn/conn.php"); 
$sql=mysql query("select count(*) as total from tb dingdan ",$conn); 


/连接 数据 库 文件 


经 提交 的 订单 。 在 该 页 面 中 ， 管 理 员 不 仅 可 以 同时 查看 多 个 用 户 的 订单 信息 ， 而 且 可 以 同时 删除 多 个 
订单 。 查 看 客户 订单 信息 的 代码 如 下 : 


S$info=mysql_fetch_array($sql); // 检 索 订单 数据 表 信 息 
S$total=$info[total]; 1/ 计算 用 户 订单 数目 
if($total==0){ /如 果 订 单数 目 为 0， 则 弹出 相关 提示 
echo "本 站 暂 无 订单 1"; 
} 
else{ // 如 果 订 单数 目 不 为 空 ， 则 输出 订单 信息 
gol /应 用 do…while 循 环 语句 输出 订单 信息 
S$array=explode("@",Sinfol[spc]); /将 记录 商品 串 存放 到 数组 Sarray 中 
© S$sum=count(Sarray)*20+260; // 设 置 弹出 订单 的 高 度 

> 

<! 一 以 下 代码 用 于 显示 商品 信息 --> 

<tr> 


<td height="21" bgcolor="#FFFFFF"><div align="center"><?php echo $infol[dingdanhao]:?></div></td> 
<td height="21" bgcolor="#FFFFFF"><div align="center"><?php echo $infol[xiadanren];?></div></td> 
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<td height="21" bgcolor="#FFFFFF"><div align="center"><?php echo S$infol[shouhuoren];?></div></td> 
<td height="21" bgcolor="#FFFFFF"><div align="center"><?php echo S$info1[total];?></div></td> 
<td height="21" bgcolor="#FFFFFF"><div align="center"><?php echo S$info1[zfff];?></div></td> 
<td height="21" bgcolor="#FFFFFF"><div align="center"><?php echo S$info1[shff];?></div></td> 
<td height="21" bgcolor="#FFFFFF"><div align="center"><?php echo $info1[zt]:;?></div></td> 
<td height="21" bgcolor="#FFFFFF"><div align="center"> 
@ <input name="button" type="button" class="buttoncss" id="button" 
onClick="javascript:window.open('showdd.php?id=<?php echo Sinfol[lid];?>",'newframe',"width=600,height=<?php 
echo $sum;?>,left=100,top=100,menubar=no0,toolbar=no,location=no,scrollbars=n0")" value=" 查 看 "> 
&nbsp; 
<input name="button2" type="button" class="buttoncss" id="button2" 
‘onClick="javascript:window.location='orderdd.php?id=<?php echo $info1[id];?>';" value=" 执 行 "> 
<input type="checkbox" name=<?php echo $infol[id];?> value=<?php echo $infol[id];?>></div></td> 
</tr> 
<?php 
}while($infol=mysql_fetch_array($sq11)); /do…while 循 环 语句 结束 


?> 


</table> 


Ah 代码 由 二 

@ $sum=count($array)*20+260;: 用 于 动态 地 改变 弹出 的 订单 的 高 度 ，count($array)*20 表示 所 有 订单 中 商品 项 的 总 
高 度 ，260 表示 除 所 有 订单 商品 项 以 外 的 高 度 ， 其 中 所 以 两 者 的 和 就 是 弹出 订单 的 总 高 度 ， 这 里 用 $sum 表示 。 以 后 只 
需 将 $sum 的 数值 赋 给 window 的 open 方法 的 height 特征 即 可 ， 这 样 弹出 订单 的 高 度 将 根据 某 条 订单 商品 数量 的 多 少 而 
增高 或 减低 。 

@ <input...>: 通过 这 段 代 码 中 的 window.open 方法 动态 地 弹出 订单 。 

管理 员 具 备 删除 订单 的 操作 权限 ， 由 于 订单 是 电子 商务 平台 的 主线 ， 因 此 ， 订 单一 旦 删除 将 不 能 
恢复 ， 因 此 管理 员 在 操作 时 要 谨慎 。 

选中 欲 删 除 的 订单 信息 后 面 的 复 选 框 〈 支 持 单条 和 多 条 订单 删除 ) ， 单 击 “ 删 除 选择 项 ”按钮 ， 
即 可 提交 表单 信息 到 数据 处 理 页 deletedd.php， 删 除 指定 的 订单 记录 。 代 码 如 下 : 

例 程 21 ”代码 位 置 ， 光盘 \TM\04\ shop\admin\lookdd.php 


<?php 
$page=intval($_POST[page id]); // 获 取 和 欲 删 除 的 订单 号 
include("conn/conn.php"); // 连 接 数 据 库 文件 
while(list($value,$name)=each($_POST)) { // 应 用 while 循 环 语句 ， 删 除 指定 的 订单 信息 

mysql_query("delete from tb_dingdan where id=".$value."",$conn); 
} 
header("location:lookdd.php?page=".$page.""); // 重 新 定位 到 编辑 订单 页 
> 


4.10.4 执行 客户 订单 信息 的 实现 过 程 


查看 客户 订单 信息 使 用 的 数据 表 : tb_dingdan、tb_shangpin 
管理 员 登 录 后 台 后 , 在 功能 导航 浮动 框架 中 单 击 “ 订 单 管理 "/“ 编 辑 订单 ” 荣 单项 ， 即 可 进入 “ 查 


So. 
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看 客户 订单 信息 ”页 面 ， 在 该 页 面 单 击 欲 执行 订单 后 面 的 “执行 ”按钮 ， 进 入 “执行 客户 订单 信息 ” 
页 面 。 该 页 面 的 的 运行 结果 如 图 4.41 所 示 。 


葬 欣 电子 商城 = 


下 = 
商品 管理 到 
0 添加 商品 TS: pornieeiensrss Ek 款 历 | ES 黄历 | Ek 符 反 [En 
日 ”修改 商品 广 : 一 旦 商品 确定 发 货 ， 该 商品 数量 将 自动 从 库存 中 相应 减少 ,并且 不 可 更 改 
商品 关中 得 商 融 名 闪 ED 市 场 从 会 员 价 成 到 俐 拆 3 水 计 
9 需 加 商品 类 别 数码 相机 1 2699 2599 2599 7% 2599 
GEE 
用 户 管理 
芽 EEC 
.用 让 全 外 管理 路 主人 返 名 : 。 隐 共 
用 户 留言 
ne ET 
更 管理 员 信 息 
页 全 
ee 电话 holonmor 
ee FET er it ee 
a 
el EE 
Se 支付 方式 支付 
EN 请 音 留言: 由 证 县， 如 全 各 让? 从 到 前 10 分 名 条 电 证 和 0 
o。 添加 公 首 十 
评论 生理 
a 


4.41 执行 客户 订单 信息 页 面 的 运行 结果 

执行 客户 订单 是 为 了 改变 订单 的 当前 状态 ， 从 而 使 管理 员 能 够 及 时 有 效 地 处 理 每 个 用 户 的 订单 ， 
并 记录 当前 订单 的 处 理 状 态 。 

在 “查看 客户 订单 信息 ”页 面 , 单 击 “ 执 行 ”按钮 , 应 用 javascript 脚本 中 的 window 对 象 的 location 
方法 跳 转 到 orderdd.php 页 ， 并 将 欲 执行 订单 的 id 号 一 并 传递 到 该 页 ， 代 码 如 下 : 

例 程 22 ”代码 位 置 ， 光盘 \TM\04\ shop\admin\lookadd.php 

<input name="button2" type="button" class="buttoncss" id="button2" onClick="javascript:window.location='orderdd.php 

?id=<?php echo $infol[id];?>":" value=" 执 行 "> 

获取 从 查看 客户 订单 信息 页 传递 过 来 的 id 值 , 应 用 mysql_query0) 函 数 检索 订单 id 所 对 应 的 详细 信 
息 。 然 后 应 用 explode() 函 数 将 该 订单 中 商品 的 id 及 这 些 商 品 的 数量 存放 到 数组 中 ， 最 后 通过 for 循环 
语句 该 订单 中 所 有 的 商品 信息 ， 执 行 客户 订单 信息 的 代码 如 下 : 

例 程 23 ”代码 位 置 ， 光盘 \TM\04\ shop\admin\orderdd.php 


<?php 
include("conn/conn.php"); 
$id=$_GET[id]; /获取 订单 id 
$sql=mysql query("select * from tb dingdan where id=".$id."",$conn); 
S$info=mysql_fetch_array($sq]): /从 dingdan 表 中 获取 该 订单 的 详细 信息 
> 
“ // 省 略 了 订单 标题 部 分 的 HTML 标 记 ， 请 参看 本 书 附 带 光 盘 
<?php 
S$array=explode("(@",$info[spe)]); 
$arraysl=explode("@",Sinfo[slc]); /将 该 订单 中 商品 的 id 及 这 些 商品 的 数量 存放 到 数组 中 
Stotal=0; 
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for($i=0;$i<count(Sarray)-1;Si++){ /通过 循环 显示 该 订单 中 所 有 的 商品 信息 
if($array[$i]!=""){ 
$sqll=mysql_query("select * from tb_shangpin where id=".$array[$i]."",$conn); 
S$infol=mysql fetch_array($sql1); 
S$total=$total+$infol [huiyuanjia]*$arraysl[$i]; /计算 订单 中 商品 的 总 价格 
> 
0 > 
<tr> 
<td height="25" bgcolor="#FFFFFF">&nbsp;<?php echo $infol[mingcheng]:;?> </td> 
<td height="25" bgcolor="#FFFFFF"><?php 这 Sinfol[shuliang]<0) echo " 售 完 "; else echo $arraysl[$i];?> </td> 
<td height="25" bgcolor="#FFFFFF"><?php echo S$infol[shichangjial;?> </td> 
<td height="25" bgcolor="#FFFFFF"><?php echo $info1[huiyuanjia];?> </td> 
<td height="25" bgcolor="#FFFFFF"><?php echo S$infol[huiyuanjia]:?></td> 
<td height="25" bgcolor="#FFFFFF"><?php echo ceil(($infol[huiyuanjial/$infol[shichangjia])*100);?>% </td> 
<td height="25" bgcolor="#FFFFFF"><?php echo S$infol[huiyuanjia]*$arraysl[$i];?> </td> 
</t> 
<<!-- -一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 -一 一 - 一 > 
<?php 
} 
} 
位 


<!-- 收 货 人 信息 显示 部 分 代码 略 --> 
选中 “已 收 款 ”、“ 已 发 货 ”、“ 已 收 货 ” 的 复 选 框 ， 单 击 “ 修 改 ” 按 钮 ， 提 交 订单 的 处 理 状 态 
到 数据 处 理 页 saveorder.php， 更 新 订单 表 的 处 理 状态 ， 并 对 商品 信息 表 中 的 商品 数量 进行 相应 减少 ， 
限于 篇 幅 ， 代 码 请 参看 本 书 附带 光盘 。 


4.10.5 打印 客户 订单 信息 的 实现 过 程 


国 ”查看 客户 订单 信息 使 用 的 数据 表 : tb_dingdan、tb_shangpin 

管理 员 登 录 后 台 后 , 在 功能 导航 浮动 框架 中 单 击 “ 订 单 管理 ”/“ 编 辑 订 单 ” 菜 单项 ， 即 可 进入 “ 查 
看 客户 订单 信息 ”页 面 ， 在 该 页 面 单 击 欲 执行 订单 后 面 的 “查看 ”按钮 ， 进 入 “打印 客户 订单 信息 ” 
页 面 ， 客 户 订单 及 打印 预览 页 面 的 运行 结果 如 图 4.42 和 图 4.43 所 示 。 


漳 http://127.0.0.1 - 商品 订单 - Microsoft Internet Explorer 


打印 预览 | 打印 


2599 
总 计 费 用 :2599| 


纯净 水 
楷 芍 
:吉林 省 长 春 市 河东 路 1t#* 号 
130000 电 话 : 。 0431-84978rye 
zixuant#@si# com 
送 货 上 门 支付 方式 : 网 上 支付 
请 您 在 一 周 内 按 您 的 支付 方式 进行 汇款 , 汇款 时 注 明 您 的 订单 号 ! 汇 款 后 请 及 时 通知 我 们 
关闭 窗口 包 障 时 间 : 2007-11-22 14:36:37 


图 4.42 客户 订单 页 面 的 运行 结果 


SS 
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当 打 印 预 宽 x| 
打印 久 ..， | 各 |* 页面 共 ! 一 小 | 隐 你 [10% 可 | 和 中 | 关闭 加 
商品 订单 图 
订单 号 : 2007112214363739 
商品 列表 0 下 ) : 
商品 名 称 市 场 价 会 员 价 数量 小 计 
数码 相机 2699 2599 1 2599 
总 计 费 用 :2599 
下 单 人 : 纯净 水 
收 货 人 : 紧 矿 
收 货 人 地 址 : ”吉林 省 长 春 市 河东 路 1#* 号 
邮 编 : 130000 电 话 : ”0431-84978+## 
E-mail rixuant*@si*. com 
送 货 方式 : 送 货 上 门 支付 方式 : 网 上 支付 


请 您 在 一 周 内 控 悠 的 支付 方式 进行 汇款 ,汇款 时 注 明 炊 的 订单 号 ! 汇 款 后 请 及 时 通知 我 们 


创建 时 间 : 2007-11-22 14:36:37 而 
| 
图 4.43 客户 订单 打印 预览 页 面 的 运行 结果 

在 电子 商务 平台 中 加 入 打印 客户 订单 的 功能 ， 不 但 可 以 使 用 户 非常 方便 的 操作 程序 、 提 高 工作 效 
率 ， 而 且 更 能 使 程序 适应 人 性 化 的 潮流 。 

在 “查看 客户 订单 信息 ”页 面 ， 单 击 “ 查 看 ”按钮 ， 应 用 JavaScript 脚本 中 的 window 对 象 的 open 
方法 打开 showdd.php 页 ， 并 将 欲 打印 订单 的 id 号 一 并 传递 到 该 页 ， 打 印 指定 id 的 订单 信息 。 代 码 
如 下 : 

例 程 24 ”代码 位 置 ， 光盘 \TM\04\ shop\admin\lookadd.php 


<input name="button" type="button" class="buttoncss" id="button" onClick="javascript:window.open('showdd.php?id= 
<?php echo Sinfollid];?>','newframe','width=600,height=<?php echo $sum:;?>,left=100,top=100,menubar=no,toolbar=no,location 
=no,scrollbars=no')" value=" 查 看 "> 


打印 客户 订单 信息 页 面 主要 应 用 WebBrowser+CSS 方法 实现 客户 订单 的 打印 ， 该 方法 简单 、 方 便 、 
快捷 ， 在 浏览 网 页 的 同时 就 可 以 实现 打印 及 打印 预览 功能 。 实 现 客户 订单 信息 打印 及 打印 预览 的 方法 
如 下 : 

例 程 25 ”代码 位 置 ， 光盘 \TM\04\ shop\admin\ showdd.php 


<! 一 定义 CSS 样 式 --> 
<style type="text/css"> 
@ Mmediaprint{ 
divfdisplay:none} 
} 
</style> 
<div align="right"> <!-- 添 加 div 层 --> 
<script> 
function prnO{ // 定 义 prn0 函 数 调用 ExecWB 方 法 实现 打印 预览 功能 
document.all. WebBrowserl.ExecWB(7,1) 
上 
</script> 
"243 乡 
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四 ”<objectID='WebBrowserl' WIDTH=0 HEIGHT=0 
CLASSID='CLSID:8856F961-340A-11D0-A96B-00C04FD705A2'></object> 
<input type="button" value=" 打 印 预览 " class="buttoncss" onclick="prn0">&nbsp; 
目 <inputtype="button" value=" 打 印 " class="buttoncss" onClick="window.print0"> 
</div> 


< 代码 贴 十 

@ @media print {div{display:none}}: 定义 打印 样式 为 不 显示 状态 。 该 功能 在 设计 表单 时 将 按钮 及 表格 均 添 加 在 div 
层 中 ， 然 后 将 所 有 应 用 div 层 的 内 容 应 用 该 样式 ， 这 样 在 打印 及 打印 预览 时 div 层 的 内 容 不 打印 ， 如 图 4.35 所 示 。 

@ <object.…></object>: 是 插入 的 ActiveX 组 件 ， 目 的 是 将 系统 的 打印 预览 功能 嵌入 该 页 函数 prn() 中 的 
document.all.WebBrowserl.ExecWB(7,1) 是 调用 该 组 件 的 ExecWB 方法 ， 从 而 实现 打印 预览 功能 。 

@ window.print(): 在 单 击 事件 下 调用 window 对 象 的 print() 方 法 实现 的 打印 功能 。 


[ED 说 明 : 关闭 窗口 是 通过 调用 window 对 象 的 close() 方 法 来 实现 的 。 如 果 用 户 浏览 器 禁用 了 Active 
组 件 ， 则 打印 预览 功能 可 能 无 法 实现 。 


4.10.6 查找 客户 订单 信息 的 实现 过 程 


国 。 查找 客户 订单 信息 使 用 的 数据 表 : tb_dingdan 
管理 员 登 录 后 台 后 ,在 功能 导航 浮动 框架 中 单 击 “ 订 单 管 理 ”/“ 查 询 订 单 ” 菜 单项 ， 即 可 进入 “ 查 
找 客户 订单 信息 ”页 面 ， 该 页 面 的 的 运行 结果 如 图 4.44 所 示 。 


荣 欣 电子 商城 


从 
上 。 商 & 管 理 
| 用 户 管理 下 订单 人 姓名 订单 号 :2007112214363739 
订单 管 理 查找 
编辑 订单 
0。 查询 订单 


订单 号 下 单 用 户 订货 人 金额 总 计 “| 付款 方式 | 收 款 方式 | 订单 状态 


| Ee oorllzz14s6a7a9 纯净 水 紫 玉 2599 网 上 支付 | 送 货 上 门 ”| 未 作 任何 处 理 | 
9 ” 公 省 管理 

9 添加 公告 
9 评论 管理 


图 4.44 查找 客户 订单 信息 页 面 的 运行 结果 


为 了 便于 系统 管理 员 管 理 订单 ， 该 系统 后 台 提供 了 管理 员 订 单 查找 功能 ， 管 理 员 可 按 下 订单 人 姓 
名 或 订单 号 查询 订单 的 相关 信息 。 
查找 订单 信息 页 面 涉及 到 的 HTML 表单 的 重要 元 素 如 表 4.2 所 示 。 


Re 


第 4 章 ”电子 商务 平台 网 (Apache+PHP+phpMyAdmin+MySQL 5.0 实现 ) 


表 4.2 查找 订单 信息 页 面 涉及 到 的 HTML 表单 的 重要 元 素 


method= "post" action= "finddd.php" 


form3 form < 5 查询 订单 表单 
onSubmit= "return chkinput3( this)" 

username text | class="inputcss” | 下 订单 人 姓名 

ddh text | class="inputcss” | 订单 号 


show _find value="show _find" 隐藏 域 


“查找 ” 按 包 


输入 查询 条 件 ， 单 击 “ 查 找 ” 按 钮 ， 提 交 表单 信息 到 数据 处 理 页 ， 对 指定 条 件 的 订单 信息 进行 检 
索 。 通 过 if 条 件 语句 进行 判断 ， 如 果 下 订单 人 姓名 为 空 ， 则 按 订 单 号 查询 ; 如 果 订 单 号 为 空 ， 则 按 下 
订单 人 姓名 查询 :如果 两 者 均 不 为 空 ， 则 按 以 上 两 个 条 件 同 时 查询 。 最后， 应 用 do…while 循环 语句 输 
出 与 查询 条 件 所 匹配 的 订单 信息 。 关 键 代码 如 下 : 

例 程 26 ”代码 位 置 ， 光盘 \TM\04\ shop\admin\finddd.php 


<?php 
if($_POST[show_find]!=""){ /1/ 如 果 表 单 被 提交 则 开始 查找 订单 信息 
$usermame=trim($_POST[username]); // 获 取 下 订单 人 姓名 
$ddh=trim($_POST[ddh]); // 获 取 订单 号 
if($username=—"")!{ 1/ 如果 下 订单 人 姓名 为 空 ， 则 按 订 单 号 查询 
$sql=mysql query("select * from tb dingdan where dingdanhao=".$ddh."",$conn); 
} 
elseif($ddh==""){ // 如 果 订 单 号 为 空 ， 则 按 下 订单 人 姓名 查询 


$sql=mysql query("select * from tb dingdan where xiadanren=".$username."",$conn); 
} 
else{ // 如 果 两 者 均 不 为 空 ， 则 按 以 上 两 个 条 件 同时 查询 
$sql=mysql_query("select * from tb_dingdan where xiadanren=".$username.""and dingdanhao=".$ddh."",$conn); 
} 
Sinfo=mysql_fetch_array($sq]l); 


if($info==false){ // 如 果 无 记录 ， 则 弹出 相关 的 提示 信息 
echo "<div algin='center> 对 不 起 ,没有 查找 到 该 订单 !</div>"; 
5 /否则 ， 按 指定 的 查询 条 件 输出 订单 信息 
罗 加 // 订 单 标题 部 分 HTML 标 记 代 码 略 ， 请 参见 光盘 
i // 应 用 do…while 循 环 语句 输出 指定 条 件 下 的 订单 信息 


<td height="25" bgcolor="#FFFFFF"><div align="center"><?php echo $info[dingdanhao];?></div></td> 
加 // 显 示 订 单 详细 内 容 部 分 代码 略 ， 请 参见 光盘 
</tr> 
<?php 
}while(Sinfo=mysql fetch array($sqD)); 
} 
} 
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4.11 开发 技巧 与 难点 分 析 


4.11.1 防止 非法 用 户 绕 过 系统 登录 直接 进入 系统 


为 了 保证 网 站 内 信息 资源 的 安全 ， 项 目 开发 人 员 应 防止 用 户 以 非法 身份 对 网 站 内 部 信息 进行 非法 
操作 ， 只 有 通过 正确 的 途径 成 功 登 录 电 子 商 务 平台 ， 才 可 以 进行 商品 的 添加 及 操作 购物 车 列表 。 如 果 
用 户 未 登录 而 直接 单 击 “ 我 的 购物 车 ”或 “购买 ” 某 项 商品 ， 则 强制 跳 到 首页 进行 登录 操作 ， 运 行 结 
果 如 图 4.45 所 示 。 

加 


AS 请 先 登 录 ， 后 购物 | 


图 4.45 登录 提示 


下 面 讲解 开发 该 功能 的 编程 思路 : 

首先 ， 在 用 户 登 录 时 应 用 session 变量 记录 用 户 名 ， 即 $_ SESSION[username]。 

然后 ， 对 登录 的 $_SESSION[username] 进 行 判断 ， 如 果 $_SESSION[username] 值 为 空 将 弹出 提示 框 ， 
如 图 4.45 所 示 ， 并 强制 将 页 面 跳 转 到 电子 商务 平台 原来 页 面 进行 用 户 登 录 。 其 代码 如 下 : 


<?php 
session_start(); /初始 化 session 变 量 
if($_SESSION[username]=="") { 1/ 判断 用 户 是 否 已 经 登录 


echo "<script>alert(' 请 先 登 录 后 购物 !""):history.back();</script>";”// 如 果 用 户 未 登录 ， 则 提示 用 户 先 登录 并 返回 到 
原来 页 面 
exit; // 用 exit 语 句 停止 循环 的 继续 执行 


} 
> 


3 技巧: 为 了 提高 代码 的 可 重用 性 ， 开 发 人 员 可 以 将 上 面 这 段 代码 独立 封装 在 PHP 文件 中 ， 并 将 文 
件 命名 ， 如 check_user.php， 然 后 将 该 文件 应 用 include 包含 语句 嵌入 在 必须 通过 登录 才能 
访问 的 页 面 中 。 如 果 用 户 未 进行 登录 ， 而 直接 通过 地 址 栏 或 其 他 手段 访问 该 页 面 时 ， 则 将 
会 弹出 用 户 先 登录 方 可 有 访问 权限 ,并 强制 跳 转 到 登录 页 。 应 用 include 包含 语句 嵌入 该 文 
件 的 代码 如 下 : 

<?php include "check_user.php";?> 

[0 说 明 : 利用 引用 语句 来 包含 其 他 文件 ， 以 减少 代码 的 重复 ， 是 PHP 编程 的 重要 技巧 。 关 于 引用 语 

名 的 详细 讲解 ， 请 读者 参见 4.7.2 节 。 
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4.11.2 ”检测 用 户 名 是 否 已 经 注册 


在 电子 商务 平台 中 ， 为 了 提高 网 站 的 安全 性 ， 在 实现 会 员 注 册 功 能 模块 时 ， 要 求 不 允许 同时 存在 
两 个 或 多 个 相同 的 用 户 名 。 

在 “用 户 昵称 ”文本 框 中 输入 用 户 名 ， 通 过 单 击 “ 检 测 用 户 ” 超 链接 对 用 户 输入 的 新 昵称 进行 检 
测 ， 并 输出 检测 结果 ， 运 行 结果 如 图 4.46 所 示 。 


A 主打 Member Enroll 


用 户 昵称 : 紫 天 本 查看 昵称 是 否 已 用 


Brasil 禁 喜 , 该 昵称 没 被 占用 ! 


联系 电话 : 确定 


图 4.46 检测 用 户 名 是 否 已 被 注册 
下 面 讲解 开发 该 功能 的 编程 思路 : 
(1) 在 会 员 注 册页 面 添加 “查看 昵称 是 否 已 用 ”按钮 ， 其 HTML 标记 的 代码 如 下 : 
<input name="button2” type="button"” onclick="chkne(form1.userne.value)” value=" 查 看 昵称 是 否 已 用 "> 


(2) 在 该 按钮 的 单 击 事件 下 调用 自 定 义 的 chknc() 函 数 , 通过 window.open 方法 打开 一 个 用 户 检测 
的 网 页 对 话 框 ， 代 码 如 下 : 


<script language="javascript"> 
function chkne(ne) { 
window.open("chkusemc.php?nc="+nc,"newframe","width=200,height=10,left=500,top=200,menubar=no,toolbar=no,loca 


tion=no,scrollbars=no,location=no"); 


} 
</script> 
(3) 将 输入 的 用 户 昵称 通过 Get 方法 提交 到 chkusernc.php 数据 处 理 页 ， 判 断 新 注册 的 用 户 昵称 
是 否 为 室 ， 如 果 为 室 ， 弹 出 提示 信息 ; 否则 ， 检 测 该 昵称 是 否 已 被 占用 。 如 果 占 用 ， 则 弹出 提示 信息 ， 
否则 提示 用 户 ， 该 昵称 可 以 注册 。 代 码 如 下 : 


<?php 
include("conn/conn.php"); // 连 接 数 据 库 文件 
Snc=trim($_GETI[ne]); /获取 用 户 昵称 
这 $nc 一 "")f /如 果 用 户 昵称 为 室 ， 则 弹出 提示 信息 
echo "请 输入 昵称 


有 
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else{ /否则 ， 检 测 用 户 昵 称 是 否 被 占用 
$sql=mysql query("select * from tb_user where name='".Snc.""",Sconn); 
Sinfo=mysql_fetch_array($sqD); /检索 数据 信息 
ifS$info 一 true){ /如 果 用 户 表 中 该 昵称 已 存在 ， 则 弹出 提示 信息 
echo "对 不 起 ,该 昵称 已 被 占用 !"; 
} 
else{ /如 果 该 昵称 不 存在 ， 说 明 可 以 注册 
echo "恭喜 ,该 昵称 没 被 占用 !"; // 弹 出 提示 信息 
} 
} 
?> 


4.11.3 ”用户 安 全 退出 


为 了 网 站 的 安全 ， 在 用 户 完成 购物 后 ， 需 要 安全 退出 电子 商务 平台 ， 需 单 击 “ 注 销 离开 ” 超 链接 ， 
即 可 在 退出 网 站 时 清空 session 变量 。 代 码 如 下 : 


<?php 

session_start(); // 启 动 会 话 
session_unset|; // 删 除 会 话 
session_destroy0; /| 结束 会 话 
header("location: index.php"); // 重 新 定位 到 首页 
es 


4.12 “加密 技术 专题 


加 密 是 在 不 安全 的 信息 渠道 中 实现 信息 安全 传输 的 一 种 重要 方法 。 因 此 对 数据 进行 加 密 操作 是 非 
常 重要 的 。PHP 中 加 密 的 方法 有 很 多 种 ， 开 发 人 员 在 应 用 加 密 技术 时 ， 可 根据 情况 进行 选择 性 使 用 。 
下 面 对 各 项 加 密 技术 进行 详细 讲解 。 


4.12.1 URL 编码 加 密 技术 


PHP 通过 GET 方法 提交 的 信息 , 会 以 查询 字符 串 的 形式 显示 在 浏览 器 的 地 址 栏 中 ,这样 会 给 网 站 
的 安全 带 来 很 大 的 隐患 ， 为 了 解决 这 个 问题 ， 可 以 对 查询 字符 串 进行 URL 编码 。 

PHP 中 实现 对 查询 字符 串 进行 URL 编码 可 以 通过 urlencode0 函 数 实现 。 该 函数 的 使 用 格式 如 下 : 

string urlencode( string str) 

该 函数 实现 将 字符 串 str 进行 URL 编码 。 

PHP 中 实现 对 URL 编码 后 的 查询 字符 串 进行 解码 通 urldecodeO 过 函数 实现 。 该 函数 的 使 用 格式 
如 下 : 


string urldecode( string str) 


Re 
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该 函数 实现 将 URL 编码 str 进行 解码 。 


下 面 应 用 urlencodeO 函 数 对 “首页 ”字符 串 进行 URL 编码 ， 代 码 如 下 : 


<a href=index.php?page=<?php echo urlencode(" 首 页 ")?> > 首页 </a> 
接收 查询 字符 串 的 值 ， 并 应 用 urldecode() 函 数 对 查询 字符 串 进行 解码 ， 代 码 如 下 : 


<?php 


echo urldecode($_GET[page]); // 对 GET 方 法 提交 的 字符 串 进行 URL 解 码 
?> 


4.12.2 base64 编码 加 密 技术 


PHP 实现 字符 串 的 base64 编码 通过 base64_encode() 函 数 实现 。 该 函数 的 语法 格式 如 下 : 
string base64_encode(string data) 
参数 data 指 要 进行 base64 编码 的 数据 。 该 函数 的 返回 结果 为 字符 串 类 型 。 
PHP 实现 对 base64 编码 的 字符 进行 解码 通过 base64_decode() 函 数 实现 。 该 函数 的 语法 格式 如 下 : 
String base64_decode (string encoded_data) 
参数 encoded_data 是 指 要 进行 base64 解码 的 字符 串 。 
下 面 应 用 base64 编码 讲解 加 密 和 解密 的 过 程 。 代 码 如 下 : 


<?php 
Spwd=111; /定义 加 密 的 密码 
echo base64_encode($pwd); /返回 加 密 后 的 值 “MTEx” 
$jiami=base64_encode(S$pwd); // 将 加 密 后 的 字符 中 赋 给 变量 
echo base64_decode(Sjiami); // 对 加 密 的 字符 串 进行 解密 ， 返 回 值 为 “111” 
> 


4.12.3 crypt() 加 密 技术 


在 Web 程序 开发 过 程 中 ， 可 以 应 用 PHP 提供 的 crypt0 函 数 来 完成 加 密 功 能 。crypt0 函 数 是 单 向 的 
加 密 函 数 ， 无 法 解密 。 经 过 加 密 的 口令 即使 被 非法 获取 ， 由 于 不 能 被 还 原 为 明文 ， 也 不 会 影响 网 站 的 
安全 性 。 

crypt0) 函 数 的 语法 格式 如 下 : 

string crypt(string str, string [salt]); 

回 str: 是 需要 加 密 的 明文 字符 串 。 

salt: 是 一 个 位 字 串 ， 能 够 影响 加 密 的 暗 码 ， 进 一 步 排除 被 破解 的 可 能 性 。 默 认 情 况 下 ， 位 字 
串 的 长 度 为 2 位 。 若 不 使 用 salt 参数 ， 则 程序 会 自动 产生 干扰 串 。 

下 面 应 用 crypt0 加 密 函 数 对 字符 串 进行 加 密 ， 代 码 如 下 : 


<?php 
S$password="111"; 


/定义 加 密 的 密码 
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$salt=substr($password,0,2): // 计 算 位 字 串 的 数值 
echo $password=crypt($password,$salt); // 返 回 加 密 后 的 值 “1115m18GD4M5g” 
2> 


4.12.4 md5() 加 密 技术 


MD5 是 在 Web 应 用 程序 中 最 常用 的 密码 加 密 算法 之 一 ， 它 和 crypt0 函 数 一 样 也 是 单项 加 密 的 。 

MD5 广泛 用 于 数据 加 密 技术 上 ， 在 很 多 网 站 中 ， 用 户 的 密码 是 以 MD5 值 的 方式 保存 的 ， 用 户 登 
录 时 ， 程 序 员 把 用 户 输入 的 密码 计算 成 MD5 值 ， 然 后 再 去 和 数据 库 中 保存 的 MD5 值 进行 比较 ， 而 程 
序 本 身 并 不 “知道 ”用 户 的 密码 的 真实 值 ， 从 而 提高 了 网 站 的 安全 性 。 

md50 函 数 用 来 计算 字符 串 的 MD5 混合 值 。 其 语法 如 下 : 

string mds(string str); 

电子 商务 平台 网 后 台 管 理 员 登录 模块 即 采 用 md5() 函 数 获取 字符 串 加 密 后 的 值 。 加 密 管理 员 密 码 的 
部 分 代码 如 下 : 


<?php 

S$str="111"; // 管 理 员 密 码 “111” 

$mstr=md5($str); // 将 管理 员 密 码 通过 md5() 函 数 加 密 

echo $mstr; // 返 回 加 密 后 的 值 “98d51a19d8al21ce581499d7b701668” 
be 


全 注意 : 电子 商务 平台 网 后 台 管 理 员 登录 页 面 采 用 了 MD5 加 密 技术 ， 具 体 代码 请 读者 参见 本 书 附 赠 
光盘 TM\04\shop\admin\index.php 文件 。 


4.13 “本章 总 结 


本 章 运 用 软件 工程 的 设计 思想 ， 通 过 一 个 完整 的 电子 商务 平台 网 带领 读者 详细 讲解 一 个 系统 的 开 
发 流程 。 同 时 ， 在 电子 商务 平台 网 的 开发 过 程 中 ， 采 用 了 浮动 框架 技术 ， 使 整个 系统 的 设计 思路 更 加 
清晰 。 通 过 本 章 的 学 习 ， 读 者 不 仅 可 以 了 解 一 般 网 站 的 开发 流程 ， 而 且 可 以 熟悉 购物 车 、 订 单 及 加 密 
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随 着 科技 的 发 展 ， 网 络 技术 已 经 深入 到 人 们 的 日 常生 活 中 ， 同 时 带 来 了 教育 方 
式 的 一 次 变革 。 而 网 络 考试 则 是 一 个 很 重要 的 方向 。 基 于 Web 技术 的 网 络 考试 系 
统 可 以 借助 于 遍布 全 球 的 Internet 进行 。 因 此 考试 既 可 以 在 本 地 进行 ， 也 可 以 在 异 
地 进行 ， 大 大 拓展 了 考试 的 灵活 性 。 并 且 缩 短 了 传统 考试 要 求 老师 打印 试卷 、 安 排 
考试 、 监 考 、 收 集 试卷 、 评 改 试 着、 讲评 试卷 和 分 析 试 卷 ， 这 个 漫长 而 复杂 的 过 程 ， 
使 考试 更 趋 于 客观、 公正。 本 章 介绍 了 一 个 具有 在 线 考试 、 即 时 阅卷 、 成 绩 查 询 以 
及 考题 和 考生 信息 管理 等 功能 的 网 络 在 线 考 试 系统 。 通 过 阅读 本 章 ， 读 者 可 以 : 


掌握 网 络 在 线 考 试 的 开发 过 程 

掌握 应 用 SQL Server 2000 创建 数据 表 、 数 据 表 
掌握 连接 SQL Server 数据 库 的 不 同方 式 

实时 显示 时 间 的 两 种 不 同 的 方法 

掌握 Ajax 无 刷新 技术 


吾 吾 吾 吾 至 
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5.1 开发 青 景 


随 着 教育 改革 的 不 断 深入 ， 近 儿 年 来 出 现 了 一 些 新 的 教育 形式 ， 如 网 上 授课 、 网 上 考试 等 。X xX 
X 高 校 是 一 所 师资 力量 非常 雄厚 的 学 校 ， 随 着 院 校 的 扩招 ， 学 生 数 量 不 断 增 加 。 为 了 适应 新 形式 的 发 
展 ， 改 变 传统 的 教学 模式 ， 方 便 学 生 随时 随地 的 对 自己 的 学 习 情况 进行 检测 ， 减 轻 教 师 的 工作 压力 ， 
现 委 托 其 他 公司 开发 网 上 在 线 考试 系统 。 这 种 无 纸 的 网 络 考试 系统 ， 使 考 务 管 理 突破 时 空 限制 ， 提 高 
考试 工作 效率 和 标准 化 水 平 ， 使 学 校 管理 者 、 教 师 和 学 生 可 以 在 任何 时 候 、 任 何 地 点 通过 网 络 进行 考 
试 。 网 络 在 线 考试 系统 已 经 成 为 教育 技术 发 展 与 研究 的 方向 。 


5.2 ”系统 分 析 


5.2.1 需求 分 析 


随 着 计算 机 技术 的 发 展 和 网 络 技术 的 日 益 成 熟 ， 通 过 网 络 进行 信息 交流 已 成 为 一 种 快捷 的 交互 方 
式 。 在 这 种 网 络 环境 下 ， 学 校 或 考试 机 构 希望 通过 建立 网 络 在 线 考试 网 站 来 扩大 知名 度 、 降 低 管 理 成 
本 和 减少 人 力 物力 的 投资 ， 从 而 为 考生 提供 更 全 面 、 更 灵活 的 服务 ， 并 全 面 、 准 确 地 对 考试 进行 跟踪 
和 评价 。 与 此 同时 ， 考 生 希 望 根据 自己 的 学 习 情况 进行 测试 ， 并 能 够 得 到 客观 、 科 学 的 评价 ， 教 务 人 
员 希 望 能 够 有 效 地 改进 现 有 的 考试 模式 ， 提 高 考试 效率 。 

通过 实际 情况 的 调查 ， 要 求 网 络 在 线 考试 系统 具有 以 下 功能 : 
界面 设计 美观 大 方 、 方 便 、 快 捷 、 操 作 灵 活 ， 树 立 企业 形象 。 

要 求实 现在 线 考试 功能 ， 自 动 核算 考试 成 绩 。 

要 求 提 供 考试 时 间 倒计时 功能 ， 使 考生 实时 了 解 考试 剩余 时 间 。 
要 求 系统 自动 阅卷 ， 保 证 考试 成 绩 真实 有 效 。 

要 求 考生 赁 准 考证 号 查询 考试 成 绩 ， 以 保证 信息 安全 。 

系统 运行 稳定 、 安 全 可 靠 。 

要 求 对 考生 及 考题 信息 进行 严格 管理 。 


5.2.2 可行 性 分 析 


办 办 办 办 办 多 办 


可 行 性 分 析 的 目的 就 是 要 用 最 小 的 代价 在 尽 可 能 短 的 时 间 内 确定 问题 是 否 能 够 解决 。 通 过 分 析 解 
法 的 利 整 ， 来 判定 系统 目标 和 规模 是 否 现实 ， 系 统 完成 后 所 能 带 来 的 效益 是 否 达到 值得 去 投资 开发 这 
个 系统 的 程度 。 网 络 在 线 考 试 系统 的 可 行 性 可 从 以 下 两 方面 考虑 。 

1. 经 济 可 行 性 

定期 的 组 织 考试 是 各 个 院 校 及 时 掌握 学 生 学 习 成 绩 的 有 效 方式 ， 利 用 网 络 在 线 考试 系统 ， 一 方面 
可 以 节省 人 力 资源 ， 降 低 考试 成 本 。 另 一 方面 ， 在 线 考试 系统 能 够 快速 进行 考试 和 评分 ， 体 现 出 考试 
的 客观 与 公正 性 。 
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2. 技术 可 行 性 
开发 一 个 网 络 在 线 考试 系统 ， 涉 及 到 的 最 核心 的 技术 问题 就 是 如 何 实 现在 不 刷新 页 面 的 情况 下 实 


时 显示 考试 时 间 及 剩余 时 间 ， 并 做 到 到 达 考 试 结束 时 间 时 自动 提交 试卷 的 功能 。 通 过 Ajax 技术 可 以 轻 
松 实现 这 些 功 能 ， 这 为 网 络 在 线 考试 系统 的 开发 提供 了 技术 保障 。 


5.3 系统 设计 


5.3.1 系统 目标 


根据 前 面 所 作 的 需求 分 析 及 用 户 的 需求 可 知 ， 网 络 在 线 考试 系统 属于 中 小 型 软件 ， 在 系统 实施 后 ， 
应 达到 以 下 目标 : 


加 ”采用 开放 、 动 态 的 系统 架构 ， 加 强 用 户 与 网 站 的 动态 交互 性 。 
回 具有 空间 性 。 被 授权 的 用 户 可 以 在 异地 登录 网 络 在 线 考试 系统 ， 无 须 到 指定 地 点 进行 考试 。 
回 操作 简单 方便 、 界 面 简洁 美观 。 
回 系统 提供 考试 时 间 倒 计时 功能 ， 使 考生 实时 了 解 考 试 剩余 时 间 。 
回 ”随机 抽取 试题 。 
回 ”实现 自动 提交 试卷 的 功能 。 当 考试 时 间 到 达 规 定时 间 时 ， 如 果 考 生还 未 提交 试卷 ， 系 统 将 自 
动 交卷 ， 以 保证 考试 严肃 、 公 正 地 进行 。 
回 系统 自动 阅卷 ， 保 证 成 绩 真 实 准确 。 
回 ”考生 可 以 查询 考试 成 绩 。 
回 ”对 考生 注册 信息 进行 管理 。 
回 系统 运行 稳定 、 安 全 可 靠 。 
5.3.2 ”系统 功能 结构 
网 络 在 线 考试 系统 的 前 台 功 能 结构 如 图 5.1 所 示 。 
网 络 在 线 苦 试 系统 的 前 台 
| ea a3] 
考 | | 考 | | 成 | | 进 | | 修 | | 退 
生 | | 生 | | 续 | | 入 || 改 | | 出 
注 | | 登 | | 查 | | 考 | | 密 | | 登 
册 | | 录 | | 询 || 场 | | 码 | | 录 
[ 显 
考 | | 选 | | 准 | | 开 | | 自 | | 示 
试 | | 择 | | 备 | | 始 | | 动 | | 考 
规 | | 课 | | 考 | | 考 | | 癌 | | 斌 
则 | | 程 | | 这 | | 二 | | 郑 | | 可 


5.1 网络 在 线 考试 系统 的 前 台 功 能 结构 图 
*。253。 乡 
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网 络 在 线 考试 系统 的 后 台 功 能 结构 如 图 5.2 所 示 。 


网 络 在 线 考试 系统 的 后 台 


I 本 


随 叫 溃 谭 喇 彤 叫 
闹 呀 并 蔷 纤 性 
背 叫 浸 煌 阅 此 
车 弹 泗 二 阅 冰 
随 吧 泗 刘 阅 章 


闹 串 中 地 鱼池 


图 5.2 网 络 在 线 考试 系统 的 后 台 功 能 结构 图 


5.3.3 ”系统 流程 图 


为 了 读者 能 够 更 好 地 学 习 ， 下 面 给 出 网 络 在 线 考试 网 的 网 站 流程 概述 及 系统 流程 图 。 


考生 在 网 络 在 线 


考试 系统 中 通过 注册 为 网 站 用 户 ， 登 录 网 站 进行 相关 操作 。 考 生 登 录 后 ， 可 以 进 


行 在 线 考试 、 查 询 成 绩 和 修改 个 人 密码 的 操作 。 在 考试 前 ， 考 生 需 要 阅读 考试 规则 、 选 择 考 试 套 题 后 
开始 考试 ， 考 试 时 间 结 束 时 ， 考 生 提 交 试 卷 ， 提 交 试 卷 的 同时 ， 系 统 将 自动 返回 本 次 考试 的 考试 结果 。 
网 站 的 管理 员 通 过 登录 模块 可 以 登录 到 网 站 的 后 台 系统 ， 对 考生 信息 、 考 试 信息 、 管 理 员 信息 进行 管 


理 。 网 络 在 线 考试 系统 的 系统 流程 如 图 5.3 所 示 。 


修改 个 人 密码 


选择 考试 套 题 


自动 阅卷 并 显 
示 考 试 成 绩 


提交 试卷 | 一 


开始 考试 | 


一 | 管理 员 信息 管理 
2 后 台 

外 (各 ) 考生 信息 管理 

管理 员 一 富 | 站 考题 类 别管 理 

| | 考题 信息 添加 

| wj 考题 信息 管理 


图 5.3 系统 流程 图 
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5.3.4 系统 预览 


网 络 在 线 考试 系统 由 多 个 页 面 组 成 ， 下 面 仅 列 出 儿 个 典型 页 面 ， 其 他 页 面 参见 光盘 中 的 源 程序 。 

考生 登录 页 面 如 图 5.4 所 示 , 该 页 面 主要 用 于 考生 登录 , 实现 在 线 考试 及 考试 成 绩 查询 等 功能 。 在 
线 考试 页 面 如 图 5.5 所 示 , 该 页 面 用 于 实现 在 线 答题 功能 , 同时 提供 了 显示 考试 时 间 和 剩余 时 间 及 自动 
提交 试卷 功能 。 


| 


上 忆 生 有 对 | 角 吧 玫 吧 | 所 可 机 | 通才 六 | 于 内 县 


考试 系统 全 


Qu ， 


Mm Pm em 
型 


my 
TE dL 


[ee nebade_onew 本 热 、toqulre 昌 通 敌 requtre_enee 古 和 习 


eel I 


| | 
图 5.4 考生 登录 页 面 (光盘 \TM\05\online ks\denglu.php ”图 5.5 在 线 考试 页 面 ( 光 盘 \TM\05\online_ks\ksks.php》 


考题 类 别管 理 页 面 如 图 5.6 所 示 , 该 页 面 主要 用 于 实现 显示 考题 类 别 的 基本 信息 、 添加 考题 类 别 和 
删除 考题 类 别 等 功能 。 考 题 信息 管理 页 面 如 图 5.7 所 示 ， 该 页 面 主要 用 于 管理 考试 题目 信息 。 


从 开征 


2 Bd 
Su | PHI | spnfeeh 各 所 
NT 
sas 
| El [BR 医 作 有 
| 于 计 往 3 FRI ESTE 习 | ee n 
| TE Ea a 1 
[ D -net 上 机 难 到 


图 5.6 考题 类 别管 理 ( 光 盘 \TM\05\…\admin\ktlb_gl.php) 5.7 ”考题 信息 管理 (光盘 \TM\05\…\admin\ktxx_gl.php) 
[0 说 明 : 由 于 路 径 太 长 ， 因 此 省 略 了 部 分 路 径 ， 省 略 的 路 径 是 : online_ks\。 
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5.3.5 ”开发 环境 


在 开发 网 络 在 线 考试 系统 时 ， 该 项 目 使 用 的 软件 开发 环境 如 下 : 
.服务 器 端 


sh 


操作 系统 : Windows 2003 Server/Linux (推荐 ) 。 
服务 器 : Apache 2.2。 

PHP 软件 : PHP 5.1.6。 

回 数据库 : SQL Server 2000。 

开发 工具 : Dreamweaver 8 。 

浏览 器 : IE 6.0 及 以 上 版 本 。 

分 状 率 : 最 佳 效果 1024X 768 像素 。 

2. 客户 端 


浏览 器 : IE 6.0 及 以 上 版 本 。 
分 辨 率 : 最 佳 效 果 1024X 768 像素 。 


5.3.6 文件 夹 组 织 结构 


办 轨 


在 编写 代码 之 前 ， 可 以 把 系统 中 可 能 用 到 的 文件 夹 先 创建 出 来 (例如 ， 创 建 一 个 名 为 images 的 文 
件 夹 ， 用 于 保存 网 站 中 所 使 用 的 图 片 ) ， 这 样 不 但 可 以 方便 以 后 的 开发 工作 ， 也 可 以 规范 网 站 的 整体 
架构 。 笔 者 在 网 络 在 线 考试 系统 中 设计 了 如 图 5.8 所 示 的 文件 夹 架构 图 。 在 开发 时 ， 只 需要 将 所 创建 的 
文件 保存 在 相应 的 文件 夹 中 即 可 。 


日 omline_ks 


同 ain 一 用 于 存 异 网 站 后 台 文件 

巴 *m 一 用 于 存 侍 数 据 库 连 接 文件 

加 inags 一 用 于 存 异 网 站 图 片 资源 

上 ji 一 一 一 一 一 一 一 一 一 一 一 用 于 存储 网 站 使 用 的 自 定义 函数 


图 5.8 ”网 络 在 线 考试 系统 的 文件 夹 组 织 结构 
5.4 ”数据 库 设计 
5.4.1 数据 库 分 析 


由 于 网 络 在 线 考试 系统 对 于 数据 的 安全 性 及 完整 性 要 求 比较 高 ， 并 且 为 了 增加 程序 的 适用 范围 ， 
还 要 保证 系统 可 以 拥有 存储 足够 多 数据 的 能 力 。SQL Server 2000 是 一 种 高 性 能 的 关系 型 数据 库 管理 系 
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统 ， 不 仅 安全 可 靠 而 且 易 于 操作 ， 已 成 为 在 线 事 务 进程 和 数据 仓库 等 最 好 的 数据 库 平台 之 一 。 综 上 所 
述 ， 本 系统 采用 SQL Server 2000 数据 库 。 


5.4.2 数据库 概 念 设计 


根据 以 上 各 节 对 系统 所 做 的 需求 分 析 、 系 统 设计 ， 规 划 出 本 系统 使 用 的 数据 库 实体 分 别 为 考生 信 
息 实 体 、 管 理 员 实体 、 考 题 类 别 实体 和 考题 信息 实体 。 下 面 将 介绍 这 几 个 实体 的 E-R 图 。 

1. 考生 信息 实体 

考生 信息 实体 包括 编号 、 考 生 姓 名 、 联 系 方式 、 准 考证 号 、 考 试 成 绩 、 考 题 类 别 、 考 试 时 间 、 联 
系 地 址 、 考 试 状 态 和 考生 密码 等 属性 。 考 生 信息 实体 的 E-R 图 如 图 5.9 所 示 。 


图 5.9 考生 信息 实体 E-R 图 
2. 管理 员 实体 
管理 员 实 体 包括 编号 、 管 理 员 名 称 和 加 密 密 码 属性 。 管 理 员 实体 的 E-R 图 如 图 5.10 所 示 。 


图 5.10 管理 员 实体 E-R 图 
3. 考题 类 别 实体 
考题 类 别 实体 包括 编号 和 考题 类 别名 称 。 考 题 类 别 实 体 的 E-R 图 如 图 5.11 所 示 。 


4 


PHP 项 目 开 发 全 程 实录 


编号 


图 5.11 考题 类 别 实体 E-R 
4. 考题 信息 实体 
考题 信息 实体 包括 编号 、 考 题 类 别 、 考 试 成 绩 、 考 题 内 容 、 考 题 答案 、 考 题 正确 答案 及 考题 所 属 
套 题 等 属性 。 考 试题 目 实体 的 E-R 图 如 图 5.12 所 示 。 


图 5.12 考题 信息 实体 E-R 图 


5.4.3 数据库 物 理 结构 


根据 5.4.2 节 的 数据 库 概念 设计 ， 可 以 创建 与 实体 对 应 的 数据 表 。 为 了 使 读者 对 本 系统 的 数据 库 的 
结构 有 一 个 更 清晰 的 认识 ， 下 面 给 出 数据 库 中 所 包含 的 数据 表 的 结构 图 ， 如 图 5.13 所 示 。 
DH_online 
tb_user (考生 信息 表 ) 
tb_admin (管理 员 信息 表 ) 
tb_kthb (考题 类 别 信 息 表 ) 
tb_kt (考题 信息 表 ) 
5.13 db_online 数据 库 所 包含 数据 表 的 结构 图 
本 系统 共 包含 4 张 数 据 表 ， 下 面 进行 详细 介绍 。 
1. tb_user (考生 信息 表 ) 
考生 信息 表 用 来 保存 考生 信息 。 该 数据 表 结 构 如 图 5.14 所 示 。 
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tb_user 
列 名 ” ”| 数据 类 型 | 长 度 [ 允 许 空 | 标识 | 标识 种 子 | ” 描述 习 
|online_id int 4 w 1 自动 编号 
online user ~ varchar 50 考生 姓名 
online_tel varchar 50 考生 联系 方式 
online mumber varchar 50 考生 准 考证 号 
online erade ~ int 4 WA 考试 成 绩 
online_subject varchar 50 WA 考题 类 别 
online_date datetime 8 Vv 考试 时 间 
online_address varchar 100 考生 联系 地 址 
online_pt int 4 ww 考试 状态 
online_pass varchar 50 考生 密码 
到 


图 5.14 考生 信息 表 结构 
2. tb_admin (管理 员 信 息 表 ) 
管理 员 信 息 表 用 来 保存 管理 员 的 用 户 名 和 密码 。 该 数据 表 结构 如 图 5.15 所 示 。 


长 度 | 允许 空 | 标识 | 标识 种 子 | 描述  。 
自动 编号 
管理 员 名 称 
管理 员 密码 


囊 


图 5.15 管理 员 信息 表 结 构 
3. tp_ktlb (考题 类 别 信息 表 ) 
考题 类 别 信息 表 用 来 保存 考题 类 别 。 该 数据 表 结 构 如 图 5.16 所 示 。 


| |omline ktlb varehar 50 考题 类 别 


图 图 


图 5.16 考题 类 别 信息 表 结 构 
4. tb_kt (考题 信息 表 ) 
考题 信息 表 用 来 保存 考试 题目 信息 和 考题 答案 等 相关 信息 。 该 数据 表 结 构 如 图 5.17 所 示 。 
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| |kt_small_lb varchar 


5.17 考题 信息 表 结构 


5.5 ”前 台 首 页 设计 


考生 通过 “考生 登录 ”模块 的 验证 后 ， 可 以 登录 到 网 络 在 线 考试 系统 的 前 台 首 页 。 前 台 首页 主要 
用 于 实现 前 台 功 能 导航 ， 该 页 面 主要 包括 考生 注册 、 考 生 登录 、 修 改 密码 、 成 绩 查 询 、 进 入 考场 和 退 
出 信息 6 个 导航 链接 。 

下 面 看 一 下 本 案例 中 提供 的 前 台 首 页 ， 该 页 面 在 本 书 光盘 中 的 路 径 为 \TM\05\online_ks\index.php， 
如 图 5.18 所 示 。 


考生 注册 ”| 考生 登录 | 修改 密码 | 成 绩 查询 | 进入 考场 | 退出 信息 


淮 考 证 号 码 [993690 室 码 : e0000e 


在 线 考 试 系统 me com 版 权 所 有 


5.18 网 络 在 线 考试 系统 前 台 首页 


Sm 
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5.5.2 前台 首页 技术 分 析 


PHP 连接 SQL Server 数据 库 的 方法 有 两 种 : 一 是 通过 ADO 方式 连接 ;二 是 通过 mssql_connect() 
函数 连接 。 下 面 分 别 介绍 这 两 种 连接 方式 。 

1. 通过 ADO 方式 连接 SQL Server 数据 库 

利用 ADO 方式 建立 与 SQL Server 数据 库 的 连接 ， 与 使 用 ADO 方式 建立 与 Access 数据 库 连 接 的 
方法 类 似 ， 建 立 连 接 是 在 本 实例 的 conn.php 文件 中 实现 的 。 其 代码 如 下 : 

<?php 

$conn=new com("adodb.connection"); 

$connstr="provider=sqloledb;data source=localhost;uid=sa;pwd=:;database=db online"; 


$conn->open($connstr); 
hi 


2. 通过 mssql_connect() 函 数 连 接 SQL Server 数据 库 

通过 mssql_connect0 函 数 建立 与 SQL Server 数据 库 的 连接 首先 应 该 配置 php.ini 文件 ， 将 
extension=php_mssql.dll 前 的 注释 去 掉 ， 然 后 重新 启动 Apache 服务 器 。 通 过 mssql_connect() 函 数 建立 与 
数据 库 连 接 的 代码 如 下 : 


<?php 
@ $conn=mssql_connect("localhost","sa",""); // 建 立 与 SQL Server 数 据 库 的 连接 
@ mssql_select_db("db_online ",Sconn); // 选 择 数据 库 

> 
< 代码 贴 十 


@ mssql_connect() 函 数 : 打开 一 个 到 SQL Server 服务 器 的 连接 。 如 果 成 功 则 返回 一 个 SQL Server 连接 标识 ; 失败 
则 返回 false。 


resource mssql_connect ( [string servername [, string username [, string password [, bool new_link]]]] ) 


参数 servername 指 SQL Server 服务 器 ; 参数 usemamer 指 用 户 名 ; 参数 password 指 用 户 密码 ; 参数 new_link 指 连 
接 标 识 。 
四 mssql_select_db() 函 数 : 选择 SQL Server 数据 库 . 如 果 成 功 则 返回 true; 失败 则 返回 false。 
bool mssql_select_db( string database_name [,resource link_identifier]) 


参数 database_name 指数 据 库 名 称 ; 参数 link_identifier 指 连 接 标 识 。 
5.5.3 前台 首 页 的 实现 过 程 


网 络 在 线 考试 系统 前 台 首 页 主要 实现 了 考生 登录 功能 ， 考 生 通过 准 考证 号 和 密码 进行 登录 。 
考生 登录 页 面 中 所 涉及 到 的 重要 表单 元 素 如 表 5.1 所 示 。 
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表 5.1 考生 登录 页 面 所 涉及 的 重要 表单 元 素 


名 称 元 素 类 型 


forml | form 


重要 属性 
method="post" action="denglu ok.php” | 表单 


online number | text id="online number" size="21 


online pass password id="online pass" size="20" 


Submit value=" 提 交 " 
考生 在 考生 登录 页 面 录 入 准确 的 准 考证 号 和 密码 后 ， 单 击 “ 提 交 ” 按 钮 ， 提 交 表 单 信息 到 数据 处 

理 页 , 应 用 mssql_query0 函 数 检 索 考生 是 否 成 功 登录 。 如果 查询 结果 为 真 , 则 将 准 考证 号 存储 在 session 

变量 中 ;否则 弹出 提示 信息 。 代 码 如 下 : 

例 程 01 ”代码 位 置 ， 光盘 \TM\05\online_ks\denglu_ok.php 


submit 


<?php 

include("conn/conn.php"); // 连 接 数 据 库 文件 
S$online_number=$_POST[online_number]; /获取 准 考证 号 
$online_pass=$_ POST[online_pass]; /获取 考生 密码 


/让 站 素 刘 间 于 订 于 于 冰 让 于 牢 于 认 半 冰 半 宇 站 站 宇 站 半 站 站 本 有 老生 的 ] 六 考 证 号 和 密码 是 否 正确 检定 机 机 可 机 机 机 可 间 束 可 间 束 间 束 冰 束 可 水 事 六 水 可 水 束 事 水 / 


© $query=mssql query("select * from tb user where online number='$online number and online pass='$online pass"); 
@ iftmssqlL_num_rows($query)>0){ /如 果 查 询 结果 为 真 
日 Session_register(online_number); /将 准 考证 号 存储 在 session 变 量 中 
echo "<script> alert(' 登 录 成 功 !); window.location.href='index.php?online= 考 试 规则 ';</script>"; 
jelsef /如 果 没 有 检索 到 数据 
echo "登录 失败 !"; /弹出 提示 信息 
} 
人 > 
Ah 代码 贴 十 


@mssql_query: 向 与 指定 的 SQL Server 服务 器 中 的 当前 活动 数据 库 发 送 一 条 SQL 查询 。 语 法 如 下 : 
Tesource mssql_query ( string query [, resource link_identifier] ) 


参数 query 为 传 入 的 是 SQL 的 指令 ; 参数 link_ identifier 传 入 的 是 由 mssql_connect() 函 数 或 mssql_pconnect() 函 数 返 
回 的 连接 号 ， 如 果 省 略 该 参数 ， 则 会 使 用 最 后 一 个 打开 的 MySQL 数据 库 连 接 。 

@ mssql_num_rows: 获取 结果 集中 行 的 数目 。 值 得 注意 的 是 ， 该 函数 仅 对 SELECT 语句 有 效 。 

@ session_register: 在 整个 域 范围 内 增加 一 个 session 变量 。 语 法 如 下 : 


boolean session_register(string name) 


参数 name 用 于 指定 新 session 变量 的 名 称 。 
5.6 ”考生 信息 模块 设计 


5.6.1 考生 信息 模块 概述 


考生 信息 模块 主要 包括 考生 注册 、 考 生 登 录 、 修 改 密码 3 个 功能 。 考 生 首先 要 注册 为 网 站 用 户 ， 
\ “262 。 
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然后 才 被 授权 登录 网 站 进行 一 系列 操作 的 权限 ; 登录 后 考生 还 可 以 修改 个 人 的 密码 。 考 生 信息 模块 的 
系统 流程 如 图 5.19 所 示 。 


图 5.19 考生 信息 模块 的 系统 流程 图 


5.6.2 ”考生 信息 模块 的 技术 分 析 


在 考生 注册 信息 模块 中 应 用 到 Ajax 无 刷新 技术 获取 考生 的 准 考证 号 码 和 密码 。 在 介绍 该 功能 的 实 
现 过 程 之 前 ， 先 对 Ajax 技术 中 的 XmlHttpRequest 对 象 的 属性 和 方法 进行 详细 的 讲解 。 

XmlHttpRequest 对 象 是 Ajax 技术 的 核心 ， 有 关 该 对 象 的 属性 和 方法 的 详细 介绍 如 表 5.2 和 表 5.3 
所 示 。 


表 5.2 XmlHttpRequest 对 象 的 属性 


属 性 描述 
readyState 返回 当前 的 请 求 状态 
onreadystatechange 当 readyState 属 性 改变 时 就 可 以 读 取 此 属性 值 
status 返回 Http 状 态 码 
responseText 将 返回 的 响应 信息 用 字符 串 表 示 
ResponseBody 返回 响应 信息 正文 ， 格 式 为 字 节 数组 
ResponseXML 将 响应 的 domcoment 对 象 解析 成 XML 文档 并 返回 
表 5.3 XmlHttpRequest 的 方法 
方法 描 述 
Open 初始 化 一 个 新 请 求 
Send 发 送 请求 
GetAllReponseHeaders 返回 所 有 Http 头 信息 
GetResponseHearder 返回 指定 的 Http 头 信息 
SetRequestHeader 添加 指定 的 Http 头 信息 
Abort 停止 当前 的 Http 请 求 
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下 面 对 XmlHttpRequest 对 象 的 常用 属性 和 方法 进行 详细 介绍 。 

1. readystate 属性 

readystate 属性 用 于 返回 当前 的 请 求 状态 ， 请 求 状态 共有 5 种 ， 如 表 5.4 所 示 。 
表 5.4 readystate 属性 值 


属 性 值 描述 
0 表示 尚未 初始 化 ， 即 未 调用 open() 方 法 
1 建立 请 求 ， 但 还 未 调用 send0 方 法 发 送 请 求 
2 发 送 请 求 
3 处 理 请 求 
4 完成 响应 ， 返 回 数据 
2. status 属性 
status 属性 用 于 返回 Http 状态 码 ， 常 用 Http 状态 码 如 表 5.5 所 示 。 
表 5.5 ”Http 状态 码 
属 性 名 描 述 
200 操作 成 功 
404 没有 发 现 文件 
500 服务 器 内 部 错误 
505 服务 器 不 支持 或 拒绝 请 求 中 指定 的 Http 版 本 


3. responseText 属性 

responseText 属性 将 返回 的 响应 信息 用 字符 串 来 表示 。 在 默认 情况 下 ， 返 回 的 响应 信息 的 编码 格式 
为 utf-8。 

4. responseXML 属性 

responseXML 属性 用 于 将 响应 的 domcoment 对 象 解析 成 XML 文档 并 返回 。 

5. open 方法 

open 方法 用 于 初始 化 一 个 新 的 请 求 。 

语法 : 


open(String method, String url, Boolean asyn, String user, String password) 


其 中 ，method 和 url 是 必 选 参数 ，asyn、user 和 password 是 可 选 参数 。open 方法 各 参数 如 表 5.6 所 示 。 
表 5.6 open 方法 参数 


参数 名 称 描 述 
method 此 参数 指明 了 新 请 求 的 调用 方法 ， 其 取 值 有 get 和 post 
url 表示 要 请 求 页 面 的 url 地 址 。 格 式 可 以 是 相对 路 径 、 绝 对 路 径 或 网 络 路 径 


Sa 
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续 表 


说 明 该 请 求 是 异步 传输 还 是 同步 传输 ， 默 认 值 为 tue〈 允许 异步 传输 ) 
服务 器 验证 时 的 用 户 名 
服务 器 验证 时 的 密码 


6. send 方法 

send 方法 用 于 发 送 请 求 到 服务 器 。 

语法 : 

send(body) 

如 果 没 有 要 发 送 的 内 容 ， 则 body 可 以 省 略 或 为 Null。 
7. GetAllReponseHeaders 方 法 
GetAlIReponseHeaders 方法 用 于 获取 响应 的 所 有 Http 头 信息 。 获 取 到 的 信息 是 按照 “名 称 / 键 值 

排列 的 ， 信 息 之 间 是 用 “: ”冒号 进行 分 隔 的 。 

语法 : 
GetAllReponseHeaders () 

8. GetResponseHeader 方 法 

GetResponseHeader 方法 是 获取 响应 中 指定 的 Http 头 信息 。 
语法 : 
GetResponseHeader(String head) 

9. SetRequestHeader 方法 

SetRequestHeader 方法 用 于 添加 一 个 Http 头 信息 。 
语法 : 

SetRequestHeader(name,value) 

其 中 ，name 表示 Http 头 名 称 ，value 表示 信息 内 容 。 
10. Abort 方 法 

Abort 方法 用 于 取消 一 个 请 求 。 

语法 : 
AbortO 


5.6.3 ”考生 注册 的 实现 过 程 


国 ”考生 注册 使 用 的 数据 表 : tb_user 
在 网 络 在 线 考试 系统 首页 ， 单 击 “ 考 生 注册 ” 超 链接 ， 即 可 进入 考生 注册 页 面 ， 输 入 个 人 的 真实 
资料 后 ， 单 击 “ 注 册 ” 按 钮 ， 系 统 将 根据 输入 的 个 人 资料 自动 生成 准 考证 号 和 考生 密码 ， 如 图 5.20 
*。265。 
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所 示 。 


A 
[xykoME .coM 考生 注册 | 考生 登录 “| 任 改 室 码 。 | 成绩 查 询 | 进入 考场 | 退出 信息 


AN KA SHIXI T 


在 线 考 汪 东 统 人 


姓 名 FF 可 及 
联系 电话 [0431-84972266 
联系 地 址 和 89- 


EJ 


小 可 记 膨 户 洱 怖 磺 抱 ， 送 是 整 的 履 考 证 时 三 982715. 向 路 三 875107. 


在 和 wrw. cxyhome. com ”版权 所 有 
图 5.20 考生 登录 页 面 的 运行 结果 
[0 说 明 : 考生 需要 通过 准 考 证 号 和 密码 登录 网 络 在 线 考试 的 核心 模块 ， 即 在 线 考试 及 成 绩 查询 等 。 

在 考生 注册 页 面 zhuce.php 页 中 实现 考生 注册 信息 的 提交 ， 并 且 通 过 Ajax 的 页 面 无 刷新 技术 获取 
考生 的 准 考证 号 和 密码 。zhuce.php 页 中 的 关键 代码 如 下 : 

例 程 02 ”代码 位 置 ， 光 盘 \TM\05\online_ks\zhuce.php 

<!--- 调 用 一 个 javascript 脚 本 文件 --> 

‘<script type="text/javascript" src="js/zhuce js.js"></script> 

<!--- 通 过 onclick 事 件 调用 一 个 自 定义 函数 --> 

<input type="button" name="Submit" value=" 注 册 " onClick="process()"> 

<!--- 输 出 一 个 div 标 签 中 的 值 --> 

<div id="divMessage" /> 

在 zhuce_jsjs 文件 中 首先 定义 一 个 createXmlHttpRequestObject0 对 象 ， 并 获取 XMLHttpRrequest 
对 象 ， 然 后 定义 xmlHttp 用 来 存储 将 要 使 用 的 XMLHttpRrequest 对 象 。 关 键 代码 如 下 : 

例 程 03 ”代码 位 置 : 光盘 \TM\05\online_ks\ijs\zhuce jsjs 


var xmlHttp=createXmlHttpRequestObject(); /定义 XMLHttpRrequest 对 象 
function createXmlHttpRequestObjectO{ /获取 XMLHttpRrequest 对 象 
var xmlHttp; // 用 来 存储 将 要 使 用 的 XMLHttpRrequest 对 象 
if(window.ActiveXObject){ // 如 果 在 intemet Explorer 下 运行 
try{ 


xmlHttp=new ActiveXObject("Microsoft. XMLHTTP"); 


S= 
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}catch(e){ 
xmlHttp=false; 


上 
jelsef // 如 果 在 Mozilla 或 其 他 的 浏览 器 下 运行 


try{ 

xmlHttp=new XMLHttpRequest(); 
}catch(e){ 

xmlHttp=false; 
} 


} 
这 !xmlHttp) /返回 创建 的 对 象 或 显示 错误 信息 
alert(" 返 回 创建 的 对 象 或 显示 错误 信息 "); 
else 
returm xmlHttp; 
} 
然后 使 用 XMLHttpRequest 对 象 创建 异步 Http 请 求 ， 定 义 函数 process()， 对 表单 中 提交 的 数据 进 
行 判 断 ， 并 且 获 取 表 单 中 输入 的 信息 ， 在 服务 器 端 执行 zhuce_ok.php 文件 ， 向 服务 器 发 送 请 求 。 关 键 
代码 如 下 : 
例 程 04 ”代码 位 置 ， 光盘 \TM\05\online_ks\js\zhuce _js.js 


function processO{ // 使 用 XMLHttpRequest 对 象 创建 异步 HTTP 请 求 
if(form1.usemame.value==""){ /如 果 考 生 姓 名 为 空 
alert(" 请 输入 姓名 ! // 则 弹出 提示 
forml.username.select(); 1/ 返回 焦点 到 考生 姓名 文本 框 
retum(false); 
if(form1.tel.value==""){ // 如 果 考 生 联系 电话 为 空 
alert(" 请 输入 电话 号 码 ! "); // 则 弹出 提示 
forml.tel.selectO); // 返 回 焦点 到 考生 联系 方式 文本 框 
return(false); 
} 
if(checkphone(form1.tel.value)!=true){ // 如 果 考 生 联 系 方式 格式 不 正确 
alert(" 您 输入 的 电话 号 码 的 格式 不 正确 ! "); // 则 弹出 提示 
form1.tel.select(); // 返 回 焦点 到 考生 联系 方式 文本 框 
retum(false); 
上 
if(form1.address.value=—""){ /如 果 考 生 联 系 地 址 为 空 
alert(" 请 输入 联系 地 址 ! " // 则 弹出 提示 
form1.address.select(); // 返 回 焦点 到 考生 联系 地 址 文本 框 
return(false); 


} 

if(xmlHttp.readyState==4 || xmlHttp.readyState 二 0){ /在 xmlHttp 对 象 不 忙 时 进行 处 理 

names = document.getElementById("username").value; /获取 用 户 在 线 表单 中 输入 的 姓名 

tels = document.getElementById("tel").value; // 获 取 用 户 在 线 表单 中 输入 的 电话 

addresss =document.getElementById("address").value; /获取 用 户 在 线 表 单 中 输入 的 地 址 

xmlHttp.open("GET","zhuce ok.php?online user="+names+"& online tel="+tels+"& 
online_address="+addresss,true); // 在 服务 器 端 执 行 zhuce_ok.php 

xmlHttp.onreadystatechange=handleServerResponse; // 定 义 获取 服务 器 端 响 应 的 方法 
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xmlHttp.sendnulD; 

jelse 

setTimeout('process()',1000); 
} 


最 后 获取 从 服务 器 端 返回 的 消息 。 关 键 代 码 如 下 : 
例 程 05 ”代码 位 置 ， 光盘 \TM\05\online_ks\js\zhuce jsjs 


// 当 收 到 服务 器 端的 消息 时 自动 执行 
function handleServerResponse(){ 
if(xmlHttp.readystate—4){ 
if(xmlHttp.status=—=200){ 

xmlResponse=xmlHttp.responseXML:; 
xmlDocumentElement=xmlResponse.documentElement; 
helloMessage=xmlDocumentElement.firstChild.data; 
// 使 用 从 服务 器 端 发 来 的 消息 更 新 客户 端 显示 的 内 容 


// 向 服务 器 发 送 请 求 


// 如 果 服 务 器 忙 ，1 秒 后 重 试 


// 在 处 理 结束 时 进入 下 一 步 

// 状 态 为 200 表 示 处 理 成 功 结束 

// 获 取 服 务 器 端 发 来 的 XML 信 息 

// 获 取 XML 中 的 文档 对 象 〈 根 对 象 ) 
/获取 第 一 个 文档 子 元 素 的 文本 信息 


document.getElementById("divMessage").innerHTML 一 <i>'+helloMessage+'</i> 


setTimeout('process()',1000); 
jelsef 
/如 果 Http 的 状态 不 是 200 表 示 发 生 错误 


// 重 新 开始 


alert("There was a problem accessing the server:"+xmlHttp.statusText); 


} 


zhuce_ok.php 文件 在 服务 器 端 被 执行 ， 将 获取 到 的 用 户 信息 和 随机 生成 的 准 考证 号 、 密 码 添加 到 
数据 库 中 ， 并 且 将 准 考证 号 和 密码 返回 到 考生 注册 页 面 中 。 关 键 代 码 如 下 : 


例 程 06 ”代码 位 置 ， 光盘 \TM\05\online_ks\zhuce_ok.php 


<?php 

header('Content-Type: text/xml); 

echo '<2xml version="1.0" encoding="gb2312" standalone="yes" ?>' 
echo '<response>'; 

@ echo $online user=$_GET[online user]; 
S$online_tel=$_GET[online_tel]; 
S$online_address=$_GET[online_address]; 

四 S$online number=substr(mt_rand(100000,999999).0,6); 
S$online_pass=substr(mt_rand( 100000,999999),0,6); 


// 创 建 一 个 XML 格 式 输出 

// 创 建 XMIL 头 

// 创 建 <response> 元 素 

/获取 考生 姓名 
/获取 考生 联系 电话 
/获取 考生 联系 地 址 

/生成 6 位 随机 的 准 考证 号 码 
/生成 6 位 随机 的 考生 密码 


/中 于 率 素来 六 六 率 素 六 太 闵 六 六 六 不 太 闪 术 闪 本 检 村 根 据 从 客户 端 获取 的 用 户 创建 输出 直下 六 下 六 六 来 六 六 六 来 当 六 六 六 率 率 六 六 素 率 率 率 素来 率 闵 六 来/ 


include("conn/conn.php"); 


$query=mssql query("insert into tb user(online user,online tel,online address,online number,online pass) 
values('$online user','$online tel','$online address','$online number,'$online pass)"); 


if($query—true)! 
echo $online user; 


echo "用 户 注册 成 功 ， 这 是 您 的 准 考证 号 码 Sonline_number. 和 密码 Sonline_ pass."; 


上 
echo '</response> 
ea 


Se 


/关闭 <response> 元 素 
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< 人 代码 贴 二 
@ $_GET 预定 义 变量 : PHP 使 用 $_GET 预定 义 变量 自动 保存 通过 get 方法 传 过 来 的 值 ， 使 用 格式 为 : 
$_GET[name] 
四 substr0 函 数 : 从 指定 的 字符 囊 中 按照 指定 的 位 置 截 取 一 定 长 度 的 字符 。 语 法 如 下 : 
string substr(string str,int start,int length) 


参数 str 指定 字符 囊 对 象 。 参数 start 指定 开始 截取 字符 串 的 位 置 。 如 果 参 数 start 为 负数 ， 则 从 字符 囊 的 末尾 开始 
截取 。 参 数 length 是 可 选 参数 ， 指 定 截取 字符 的 个 数 ， 如 果 length 为 负数 ， 则 表示 取 到 倒数 第 length 个 字符 。 


5.6.4 ”单元 测试 


在 应 用 Ajax 技术 实现 在 线 考试 的 用 户 注册 模块 后 , 为 保证 程序 能 够 正常 运行 , 必须 对 其 进行 测试 。 
运行 考生 注册 模块 ， 运 行 结果 如 图 5.21 所 示 。 


Internet Explorer x 
Xx| 


该 网 页 上 的 问题 可 能 使 其 无 法 正常 显示 或 功能 不 正常 。 以 后 ,双击 显示 在 状态 
栏 中 的 璧 省 图 标 ， 就 可 以 显示 上 述 信息 。 


JY 网 页 包含 错误 时 始终 显示 该 信息 必 ) 。 


| 隐藏 详细 信息 四) «| 


: 84 
: 
: 缺 : 


少 对 象 


:0 
:http://127.0.0. 17Tsoftyonline_ksyindex. php?online= 用 户 注册 


上 一 个 四 ) | FT 


图 5.21 考生 注册 模块 运行 出 现 的 错误 


从 弹出 的 错误 信息 来 看 ， 是 程序 中 与 JavaScript 脚本 有 关 的 内 容 出 现 问 题 , 经 过 反复 测试 和 查找 发 
现 ， 问 题 不 是 出 现在 zhuce_js.js 文件 中 ， 因 为 在 该 文件 中 定义 的 自 定义 函数 process0 是 可 以 运行 的 ， 
所 以 问题 应 该 是 出 现在 对 服务 器 返回 的 信息 进行 输出 中 ， 即 zhuce_ok.php 文件 中 。 对 该 文件 进行 分 析 
发 现 ， 原 来 在 应 用 Ajax 技术 中 ， 服 务 器 端 返回 的 消息 采用 的 是 XML 格式 。 可 是 在 客户 端 接收 XML 
文档 时 却 忽略 了 “header('Content-Type: textxml);” 头 部 信息 的 使 用 ， 从 而 导致 客户 端 用 于 解析 XML 
的 API 抛 出 一 个 错误 信息 。 只 有 在 设置 头 部 信息 (header(Content-Type: textxml);) 后 ， 客 户 端 才 可 以 
正确 的 接收 到 服务 器 端 传递 的 XML 文档 信息 。 正 确 的 程序 代码 如 下 : 
*。269 。 乡 


<?php 
// 创 建 一 个 XML 格 式 输出 
header('Content-Type: text/xml"); /标记 输出 的 是 XML 文档 
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/创建 XMI 头 
echo '<?xml version="1.0" encoding="gb2312" standalone= "yes" ?>"; 
?> 


5.7 在线 考试 模块 设计 


5.7.1 在 线 考试 模块 的 概述 


在 线 考试 模块 的 主要 功能 是 允许 考生 在 网 站 上 针对 指定 的 课程 进行 考试 。 在 该 模块 中 ， 考 生 首先 
需要 登录 到 本 系统 中 ， 阅 读 考试 规则 ， 在 同意 所 列 出 的 考试 规则 后 ， 才 能 选择 考试 类 别 和 套 题 ， 然 后 
进入 考试 页 面 进行 答题 ， 当 考生 提交 试卷 或 者 到 达 考 试 结束 时 间 时 ， 系 统 将 自动 对 考生 提交 的 试卷 进 
行 评 分 ， 并 给 出 最 终 考试 成 绩 。 在 线 考试 模块 的 系统 流程 如 图 5.22 所 示 。 


El 
万 


选择 考题 类 别 和 套 题 
在 线 考试 


提交 试卷/ 到达 考 试 结束 时 间 
显示 本 次 考试 成 绩 


图 5.22 在 线 考试 模块 的 系统 流程 图 


5.7.2 在线 考试 模块 的 技术 分 析 


在 线 考 试 模块 中 最 核心 的 功能 是 如 何 输出 考题 、 如 何 对 提交 的 答案 进行 判断 ， 并 且 将 答案 输出 到 
当前 页 中 ， 这 是 在 线 考 试 最 关键 之 处 。 下 面 就 讲解 一 下 该 技术 的 实现 方法 ， 由 于 上 述 3 方面 的 内 容 都 
是 在 同一 页 面 中 显示 ， 所 以 在 技术 实现 过 程 中 这 3 个 方面 的 内 容 是 以 一 个 整体 形式 出 现 。 这 里 以 单 选 


题 为 例 进行 讲解 。 
Sm 
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首先 以 上 一 页 表单 中 提交 的 值 为 条 件 , 执行 查询 语句 ,通过 while 循环 语句 输出 查询 结果 ; 然后 根 
据 输出 的 查询 结果 创建 单 选 按钮 组 ， 生 成 考题 ， 最 后 ， 将 考题 答案 提交 到 本 页 ， 对 提交 的 答案 与 数据 
库 中 存储 的 正确 答案 进行 比较 ， 并 且 将 答案 输出 到 本 页 中 。 单 选 题 输出 、 答 案 判 断 和 考题 答案 输出 的 
关键 代码 如 下 : 

例 程 07 ”代码 位 置 ， 光盘 \TM\05\online_ks\ksks.php 


<?php 
证 根 据 提交 的 变量 执行 查询 语句 ， 从 数据 库 中 读 取 数 据 ， 指 定 考题 的 类 型 为 0%， 表 示 为 单 选 题 */ 
$query0=mssql query("select * from tb kt where kt lb='$kt lbes' and kt lx="0' and kt small Ib='$kt small lb"); 


$x=1; // 定 义 变量 $x=1， 用 于 输出 题 号 
S$fen0=0; // 定 义 变量 $fen0=0， 用 于 考试 分 数 的 计算 
while($myrow0=mssql_fetch_array($query0)){ // 执 行 while 循 环 语句 

> 

<tr> 


<!--- 输出 单 选 题 的 题 号 、 考 题 内 容 以 及 该 道 体 的 分 数 ---> 
<td width="443" height="20" bgcolor="#FFFFFF">&nbsp:&nbsp:<2php echo $x.".".$myrowO["kt nr"]?> </td> 
<td bgcolor="#FFFFFF"><?php echo $myrowO[kt_fs];?></td> 


和 > 
</tr> 
<?php 
/***** 获 取 考题 提交 的 答案 ， 将 提交 的 考题 答案 进行 分 割 ， 并 赋 给 变量 $strO0*******#/ 
$array0=explode("*",$myrowO["kt_daan"]); /将 数据 库 中 的 考题 答案 以 * 进 行 分 割 , 并 写 入 到 数组 中 
if($_POST[Submit]!=""){ // 判 断 表单 提交 是 否 为 空 
for$a=0;$a<count($array0);$a++){ /循环 输出 数组 中 的 答案 
if($arrayO[$a]!=""){ /数组 中 的 值 不 为 空 


if($array0[$a]==$_POST[S$Smyrow0[kt_id]]) {// 如 果 数 组 中 的 值 与 表单 提交 的 值 相 等 
$str0=$_POST[$myrowO[kt_id]]; // 将 表单 提交 的 值 赋 给 变量 $str0 
| 


b 


/来 素 半 六 素 素 闵 六 闪 素 六 闪 六 率 素 达 六 闪 闵 来 六 闪闪 来 六 闪 闵 率 素 达 六 闪闪 半球 六 闪 半 闪 素 六 闪 六 弟 素 六 率 六 六 率 素 闪 站 半 / 
for($a=0:$a<count($array0):$a++)f /执行 for 循 环 语句 ， 根 据 考 题 答案 来 决定 循环 的 次 数 
if($arrayO[$a]!=""){ /判断 如 果 考 题 答案 不 为 空 ， 则 执行 下 面 的 内 容 
= 
<tr> 
<td height="20" bgcolor="#FFFFFF">&nbsp:&nbsp; 
<!--- 创建 单 选 按钮 组 ， 用 于 提交 答案 ---> 
<input type="radio" name="<?php echo $myrowO[kt_id];?>" value="<?php echo $array0[$a]:?>"> 


<?php echo $array0[$al:?> 
<1 > 
</td> 
<td bgcolor="#FFFFFF"> &nbsp; 
<2php 
/中 六 兴 兴 闪闪 六 六 六 闪闪 六 不 六 六 术 站 站 相 村 相 站 相关 | 了 采 提 交 的 答案 是 否 正 确 ， 并 且 输 出 答案 * 下 六 下 六 闵 六 玉 六 六 六 六 来 六 闵 六 率 率 率 率 水 闵 p* 素 素 / 
if($_POST[$myrowO[kt_id]]==true){ // 判 断 表单 提交 的 值 是 否 为 空 
if($a=—=0) // 如 果 变量 $a 一 0 则 输出 下 面 的 内 容 
这 $myrow0["kt_zqdaan"] 一 Sstr0){ // 浏 断 提交 的 答案 是 否 与 数据 库 中 的 正确 答案 相同 
/如 果 提 交 的 答案 正确 ， 则 输出 下 面 的 内 容 
echo "您 输入 的 答案 &nbsp;"; 


echo "<font color=#FF0000'>".substr($str0.0,1)."</font>"; /获取 答案 的 选项 
271 g 
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echo "&nbsp; 正 确 &nbsp;&nbsp; 分 数 :"; 


echo "<font color=#FF0000>".$myrowO[kt_fs]."</font>"; // 输 出 考题 的 分 数 
Sfen0+=$myrowO["kt_fs"]; // 对 考题 的 分 数 进行 合算 
jelsef /如 果 提 交 的 答案 不 正确 则 输出 下 面 的 内 容 
echo "您 输入 的 答案 &nbsp;"; 
echo "<font color=#FF0000'>".substr( $str0,0,1)."</font>"; 
echo "&nbsp; 错 误 &nbsp;&nbsp;"; 
echo "正确 答案 :&nbsp:<font color='#FF0000'>".substr($myrow0[kt_zqdaan],0,1)."</font>" ; 
, 
上 
?></td> 
<2php 
» 
和 // 实 现 考 题 题 号 的 循环 
eo 


5.7.3 应 用 Ajax 在 线 答题 的 实现 过 程 


在 线 答题 是 本 项 目 中 最 核心 的 技术 ， 也 是 本 系统 开发 的 最 终 目的 。 在 线 答题 模块 的 主要 功能 是 实 
现在 线 考试 ， 在 当前 页 面 中 输出 考题 答案 和 考试 成 绩 ， 并 且 采 用 计时 控制 考试 时 间 ， 如 果 考 试 超过 考 
试 时 间 则 系统 自动 提交 考题 答案 ， 并 给 出 考试 成 绩 。 

考试 时 间 计时 和 剩余 时 间 的 计算 是 应 用 Ajax 技术 来 实现 的 ， 有 关 该 技术 的 实现 方法 可 以 参考 本 章 
开发 技巧 与 难点 分 析 中 的 通过 Ajax 技术 实现 计时 与 显示 剩余 时 间 一 节 。 这 里 不 讲解 。 

在 线 答题 技术 中 对 单 选 题 的 处 理 方法 已 经 在 技术 分 析 中 进行 了 详细 的 讲解 ， 这 里 就 不 再 效 述 ， 下 
面 讲解 在 线 答题 中 多 选 题 的 处 理 方法 ， 其 实现 的 原理 与 单 选 题 是 相同 的 ， 只 是 在 输出 考题 的 答案 时 使 
用 的 是 复 选 框 ， 不 再 是 单 选 按钮 组 ， 并 且 在 对 复 选 框 名 称 进 行 设置 时 增加 一 个 变量 来 对 不 同 考题 的 答 
案 进行 区 分 。 首 先 以 上 一 页 表单 中 提交 的 值 为 条 件 ， 执 行 查询 语句 ， 通 过 while 语句 输出 查询 结果 ; 然 
后 根据 输出 的 查询 结果 创建 复 选 框 ， 生 成 考题 ， 最 后 ， 将 考题 答案 提交 到 本 页 ， 对 提交 的 答案 与 数据 
库 中 存储 的 正确 答案 进行 比较 ， 并 且 将 答案 输出 到 本 页 中 。 

首先 从 数据 库 中 读 取 数 据 ， 定 义 输出 考题 时 应 用 到 的 变量 值 ， 并 且 输 出 考题 的 编号 和 内 容 。 关 键 
代码 如 下 : 

例 程 08 ”代码 位 置 ， 光 盘 \TM\05\online_ks\ksks.php 

<?ph 


p 
// 根 据 表单 提交 的 值 执行 查询 语句 ， 从 数据 库 中 读 取 符合 条 件 的 数据 
$queryl=mssql] query("select * from tb kt where kt lb='$kt lbes and kt lx='1 and kt small lb='$kt small lb"™); 


$y=1; // 定 义 变量 $y 用 于 生成 考题 编号 
$fen1=0; // 定 义 变 量 $fen1 用 于 分 数 的 统计 
$ii=0; /定义 变量 $ii 用 于 控制 考题 答案 输出 的 次 数 
while($myrowl=mssql_fetch_array($query1){ // 循 环 输出 数据 
2 
i 输出 考题 编号 和 考题 的 内 容 - 一 -一 一- 一 一 一 一 一 一 一- 一 一 一 > 
<t> 


<td height="20" bgcolor="#FFFFFF">&nbsp;&nbsp;<?php echo $y.".".$myrow1["kt_nr"]?> </td> 
<td bgcolor="#FFFFFF"><?php echo $myrow1[kt fs];?></td> 
</t> 


< 一 -> 
wa 
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然后 ， 对 表单 中 提交 的 答案 进行 处 理 ， 与 数据 库 中 存储 的 正确 答案 相 比较 ， 如 果 答 案 正 确 则 将 表 
单 提交 的 答案 写 入 到 一 个 空 是 数组 中 。 代 码 如 下 : 
例 程 09 ”代码 位 置 ， 光盘 \TM\05\online_ks\ksks.php 
?ph 
Ew ed 输出 考题 答案 **** 玉 下 于 站 六 冰冰 闪 六 来 冰球 闪 闵 率 素 来 六/ 
S$array_al=array(); // 定 义 一 个 空 数组 
// 将 数据 库 中 考题 的 答案 以 * 进 行 分 割 ， 存 储 到 数组 $array1 中 
© Sarrayl=explode("*",$myrow1["kt daan"]); 
if($_POST[Submit]!=""){ /判断 表单 提交 的 值 是 否 为 空 
for($i=0;$i<count($array1);$i++){ 1/ 循环 读 取 数组 $array1 中 的 考题 答案 
if($array1 [$i]!=""){ // 浏 断 数组 中 的 答案 是 否 为 空 
/对 表单 中 提交 的 答案 与 数据 库 中 的 答案 进行 比较 
if($array1 [$i]=—=$ POST[$myrow 1[kt id]."-".$i]) { 
// 如 果 答 案 相 同 则 将 表单 提交 的 答案 写 入 到 空 数组 $array_al 中 
四 array_push($array al.$ POST[Smyrow1[kt id]."-".$i]); 


Ah 代码 由 二 
@ explode0 函 数 : 将 字符 囊 依 指定 的 字符 囊 或 字符 separator 切 开 。 
array explode(string separator, string string, [int limit]) 


返回 由 字符 囊 组 成 的 数组 ， 每 个 元 素 都 是 string 的 一 个 子囊 ， 它 们 被 字符 囊 separator 作为 边界 点 分 隔 出 来 。 如 果 
设置 了 limit 参数 ， 则 返回 的 数组 包含 最 多 limit 个 元 素 ， 而 最 后 那个 元 素 将 包含 string 的 剩余 部 分 ; 如 果 separator 为 空 
字符 事 (") ，explode() 函 数 将 返回 false; 如 果 separator 所 包含 的 值 在 string 中 找 不 到 ， 那 么 explode(0) 函 数 将 返回 包含 
string 单个 元 素 的 数组 ; 如 果 参 数 limit 是 负数 ， 则 返回 除了 最 后 的 -limit 个 元 素 外 的 所 有 元 素 。 

@ array_push() 函 数 : 将 数组 当成 一 个 栈 ， 并 将 传 入 的 变量 压 入 该 数组 的 末尾 。 该 数组 的 长 度 将 增加 入 栈 变 量 的 数 
目 。 返 回 数组 新 的 单元 总 数 。 

int array_push ( array array, mixed var [, mixed ...]) 


参数 array: 指 输入 的 数组 ; 参数 var: 必要 参数 ， 用 来 压 入 数组 的 。 


接着 创建 考题 提交 的 复 选 框 ， 根 据 考题 的 ID 和 变量 $I 定义 复 选 框 的 名 称 。 代 码 如 下 : 
例 程 10 ”代码 位 置 ， 光盘 \TM\05\online_ks\ksks.php 


<?php 
$strl=implode("*",$array_al ); // 以 * 来 分 割 数组 Sarray al 中 的 数据 ， 返 回 值 为 变量 $str1 
for($i=0;$i<count($array1):$i++){ /根据 数据 库 中 存储 的 答案 执行 循环 语句 
这 $arrayl[$i]!=""){ // 浏 断 答案 不 为 空 
> 
<tr><td height="20" bgcolor="#FFFFFF">&nbsp;é&nbsp; 


<input type='checkbox' name=<?php echo Smyrowl[kt id]."-".$i?>' value='<?php echo $array 1[$i];?>'> <?php echo 


7.9 
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S$array1[$i];?> 
3 


</td><td bgcolor="#FFFFFF">é&nbsp; 

再 次 对 提交 的 答案 进行 判断 ， 其 中 主要 应 用 的 是 explode()、list0 和 substr0 函 数 来 实现 答案 的 判断 
和 输出 。 程 序 代码 如 下 : 

例 程 11 ”代码 位 置 :光盘 \TM\05\online_ks\ksks.php 


?ph 
和 2 本 本 率 本 六 本 率 术 本 本 本 本 本 本 本 本 本 本 本 本 对 提交 的 答案 进行 判断 入 并 且 输 出 答案 和 最 终 得 分 *** 半 六 六 六 闪 妆 这 率 素 水 六 这 于 闪 六 六 闪 六 闪闪 / 
if($_POST[$myrow1[kt_id]."-".$i]=—true)!{ // 判 断 提交 的 答案 是 否 为 真 
ifSii 一 0){ // 判 断 变量 $i 的 值 是 否 为 0%， 控 制 答案 输出 的 次 数 
if($myrow1["kt_zqdaan"]==$str1){ // 判 断 表单 提交 的 答案 是 否 与 数据 库 中 的 正确 答案 相等 
让 闪 率 认 率 认 兴 闪闪 半 兴 兴 宗 补 加 [] 果 答 案 正 确 ， 则 输出 提交 的 答案 并 且 给 出 该 题 的 得 分 *** 六 六 六 六 六 闵 六 六 闪闪 */ 
echo "您 输入 的 答案 &nbsp;"; 
S$arrayesg=explode("*",$str1); // 以 * 来 分 隔 提 交 的 答案 
© for($gg=0:$gg<count($arrayesg):$gg++){ // 循 环 读 取 答案 的 内 容 
@ list($name, $valuesg)=each($arrayesg); /输出 答案 
echo "<font color=#FF0000'>".substr($valuesg,0,1)."</font>"; 。“”// 截 取 答案 的 内 容 
} 
echo "&nbsp; 正 确 &nbsp;&nbsp; 分 数 :"; 
echo "<font color=#FF0000>".$myrow]1[kt fs]."</font>"; 
Sfenl+=$myrow1["kt_fs"]; // 统 计 考题 的 分 数 
jelsef 
/* ## 站 站 二 站 *## 如 果 输 出 的 答案 错误 ， 则 提示 您 输入 的 答案 错误 ， 并 给 出 正确 的 答案 *#yyyyyy#yy #/ 
echo "您 输入 的 答案 &nbsp;"; 
$arrayes=explode("*",$strl); 
for($g=0;$g<count($arrayes);$g++){ 
list($name,$values)=each( $arrayes); 
echo "<font color=#FF0000'>".substr($values,0,1)."</font>"; 
上 
echo "&nbsp: 错 误 &nbsp:&nbsp: 正 确 答案 :&nbsp:"; 
$arrayes=explode("*",$myrow1[kt zqdaan]); 
for($g=0;$g<count($arrayes);$g++){ 
list($name,$values)=each($arrayes); 
echo "<font color=#FF0000'>".substr($values,0,1)."</font>"; 
} 
Bh 
}$ii=1; // 控 制 每 道 题 的 答案 只 输出 一 次 数 
} 
7></td></tr> 
<?php} } 
$y+t; // 控 制 每 道 题 的 题 号 
} 
> 
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< 代码 贴 十 
@ count0 函 数 : 返回 数组 中 的 单元 数目 ， 用 来 计算 数组 中 值 的 个 数 。 
int count ( mixed array [, int mode]) 
参数 array: 必要 参数 ， 输 入 的 数组 ; 参数 mode: 可 选 参数 ， 此 参数 的 默认 值 是 0。 
@ list() 函 数 : 把 数组 中 的 值 赋 给 一 些 变 量 。 与 array() 函 数 类 似 ， 这 不 是 真正 的 函数 ， 而 是 语言 结构 。list() 函 数 仅 
能 用 于 数字 索引 的 数组 ， 且 数字 索引 从 0 开始 。 
void list ( mixed ...) 
参数 mixed 为 被 赋 值 的 变量 名 称 。 
each() 函 数 : 返回 数组 中 当前 指针 位 置 的 键 名 和 对 应 的 值 ， 并 向 前 移动 数组 指针 。 
array each ( array array) 


参数 array 为 输入 的 数组 。 
5.7.4 ”分数 统计 和 成 绩 保存 的 实现 过 程 


在 线 考 试 模块 中 不 但 完成 考试 的 答题 和 判 卷 的 操作 ， 而 且 可 以 直接 对 考试 的 分 数 进 行 统计 ， 获 取 
考生 的 最 终 得 分 ， 将 考生 的 成 绩 保 存 到 数据 库 中 ， 并 且 更 改 数据 库 中 考生 的 考试 信息 ， 说 明 该 考生 已 
经 完成 本 次 考试 ， 不 可 以 再 进行 本 类 别 的 考试 。 考 试 分 数 统计 和 存储 考试 成 绩 的 关键 代码 如 下 : 

例 程 12 ”代码 位 置 ; 光盘 \TM\05\online_ks\ksks.php 


<?php 
/中 于 来 率 素 六 六 六 来 村 不 本 站 站 相 红 计 考生 的 考试 成 绩 ， 其 中 的 变量 分 别 代表 考生 各 个 题 型 的 得 分 ** 于 于 六 六 来 六 素 六 来 素 六 率 素 来 半 / 
$zf=$fenO+ $fenl+S$fen2+$fen3; // 考 试题 分 数 统计 
echo "您 的 总 成 绩 是 :"; /输出 字符 串 
echo $zf; /输出 考试 成 绩 
> 
<2php 
/ 束 素 冰冰 冰冰 素 于 于 半 半球 于 冰球 束 率 素 素 素 率 率 束 束 素 率 率 冰 事 于 素 灶 站 间 和 考生 的 程序 存 储 到 | 数据 库 中 李 相 率 本 中 员 中 于 虽 虽 于 可 束 束 事 束 来 来 束 事 事 束 事 玉 事 求 束 事 冰 事 素 冰 */ 
if($Submit=" 提 交 "){ // 首 先 判 断 考生 是 否 提交 考题 的 答案 
$data=date("Y-m-d H:i:s"); // 获 取 考 试 的 时 间 


/水球 于 于 于 水 末 六 束 于 于 于 于 半球 于 于 间 呈 呈 字 于 于 于 计 可 订 本 来 站 于 和 老 和 -和 和] 和 序 存 : 佬 到 | 北 撕 | 库 中 于 下 下 下 下 六 于 冰 于 六 守 半 半球 素 半 率 六 半 冰 永 六 六 半 / 
$grade="update tb user set online grade='$zf,online subject=$ POSTI[kt lbes]',online pt=1,online date='$data' where 
online number-'$ SESSION[online number]"; 
$grade result=mssql query($grade); 
} 
> 


5.7.5 ”单元 测试 


在 完成 在 线 考试 模块 的 设计 后 对 该 模块 进行 测试 ， 发 现在 执行 多 选 题 提交 的 过 程 中 ， 没 有 任何 值 
返回 。 但 是 在 执行 单 选 题 提交 时 可 以 正常 运行 ， 查 看 该 文件 的 源 文件 发 现 ， 原 来 错误 出 现在 复 选 框 名 


25. 
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称 的 设置 上 ， 所 有 复 选 框 都 是 相同 的 值 ， 其 运行 结果 如 图 5.23 所 示 。 
Bi 下 Ee 


文件 到) 编辑 下) 格式 (0) 查看 G) 帮助 0 


<tr> 
<td height="28"" bgcolor=""#FFFFFF">&nbsp;&nbsp; 
<input type="checkbox' name="17' value="C PHP’> C PHP</td> 
《td bgcolor="#FFFFFF">8nbsp;</td> 


<td height="28" bgcolor="#FFFFFF">&nbsp;&nbsp; 
<input type="checkbox' name="17' value="D ASP’> D ASP</td> 
《td bgcolor="#FFFFFF">8@nbsp;</td> 
<Ztr> 


图 5.23 查看 源 文件 的 结果 

在 设置 复 选 框 的 名 称 时 必须 为 每 一 个 题 设置 不 同 的 复 选 框 名 称 ， 和 否则 将 不 能 获取 到 表单 提交 的 数 
据 ， 这 就 是 多 选 题 与 单 选 题 进行 输出 和 判断 的 主要 区 别 ， 多 选 题 中 有 多 个 答案 ， 而 单 选 题 只 有 一 个 ， 
所 以 单 选 题 的 单 选 按 钮 组 的 名 称 可 以 直接 使 用 考题 的 ID 进行 命名 ， 但 是 多 选 题 必须 在 考题 ID 的 基础 
之 上 在 定义 一 个 变量 来 区 分 每 个 复 选 框 的 名 称 。 在 程序 中 ， 错 误 的 复 选 框 名 称 定义 的 代码 如 下 : 

<input type="radio" name="<?php echo $myrowO[kt_id];?>" value="<?php echo $array0[$a];?>"> 

正确 的 复 选 框 名 称 定义 应 该 是 在 考题 ID 的 基础 之 上 加 一 个 变量 $1， 程 序 代 码 如 下 : 

<input type='checkbox' name="<?php echo $myrow1 [kt_id]."-".$i?>" value='<?php echo $array 1[$1];?>'> 

对 程序 代码 进行 修改 ， 重 新 保存 ， 程 序 可 以 正常 运行 。 


5.8 ”后台 首页 设计 


5.8.1 后 台 首 页 概述 


网 络 在 线 考试 系统 的 后 台 站 在 该 页 面 中 ， 管 理 员 可 以 
人 i 台 管理 系统 包含 的 基本 操作 。 网 络 在 线 考试 网 后 台 首 页 包含 的 主要 模块 如 下 

回 ”管理 员 信息 管理 ; 主要 用 于 修改 管理 员 信息 。 

回 ”考生 信息 管理 : 主要 包括 查看 注册 考生 信息 列表 和 考生 信息 查询 、 考 试 成 绩 查 询 和 删除 已 注 
册 的 考生 信息 。 
考题 类 别管 理 : 主要 包括 查看 考题 类 别 列表 、 添 加 考题 类 别 信息 和 删除 考题 类 别 信息 。 
考题 信息 添加 : 主要 用 于 添加 为 各 类 套 题 添加 单 选 题 、 多 选 题 、 问 答题 和 论述 题 ， 并 设置 每 
题 的 分 数 及 内 容 。 
考题 信息 管理 : 主要 包括 查看 考题 类 别 列表 、 修 改 套 题 信息 和 删除 套 题 信息 。 
包括 查看 考试 题目 列表 、 添 加 考试 题目 、 修 改 考试 题目 和 删除 考试 题目 。 
退出 管理 : 主要 用 于 退出 后 台 管 理 系统 。 


加 加 回 
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下 面 看 一 下 本 案例 中 提供 的 后 台 首 页 , 该 页 面 在 本 书 光盘 中 的 路 径 为 \TM\05\online_ks\admin\index. 
php， 如 图 5.24 所 示 。 


管理 | 考题 类 别管 理 考题 信 J 考题 信息 管理 
上 | | 

pan J i 

5 万 过 让 守 


XIAN KAO SHI 


EE DIO WO THT rT 


会 在 线 考 试 系统 后 台 管 理 > 考生 信息 管理 


惟 考 证 号 : 考题 类 别 

淮 考 证 号 考生 姓名 考生 电话 分 数 考题 类 别 操作 
993690 小 可 凡 0431-84972261 100 | PHP 上 机 考题 | 删除 
982715 西 玲 雪 0431-84972266 80 | PHP 上 机 考题 


图 5.24 网 络 在 线 考试 系统 的 后 台 首 页 


5.8.2 ”后台 首 页 技术 分 析 


网 络 在 线 考试 后 台 应 用 switch 语句 实现 的 一 种 类 似 于 框架 的 网 页 嵌 套 技术 。 为 了 能 够 更 好 地 理解 
这 个 技术 ， 下 面 进行 详细 介绍 。 

switch 语句 一 行 接 一 行 地 执行 (实际 上 是 语句 接 语 句 ) ， 开 始 时 没有 代码 被 执行 。 仅 当 一 个 case 
语句 中 的 值 和 switch 表达 式 的 值 匹配 时 ，PHP 才 开 始 执行 语句 ， 直 到 switch 的 程序 段 结束 或 者 遇 到 第 
一 个 break 语 名 为止。 如果 不 在 case 的 语句 段 最 后 写 上 break 的 话 ，PHP 将 继续 执行 下 一 个 case 中 的 
语句 段 。 

switch 语句 的 语法 如 下 : 

switch(expn) { 

case value : statement; break; 
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switch 语句 的 参数 说 明 如 表 5.7 所 示 。 
表 5.7 switch 语句 的 参数 说 明 
参数 说 明 


expr | 必要 参数 。 定 义 判断 的 条 件 表达 式 
Statement 必要 参数 。 满 足 条 件 后 ， 循 环 执行 的 语句 


5.8.3 后台 首页 的 实现 过 程 


网 络 在 线 考 试 后 台 主要 应 用 了 switch 语句 和 include 包含 语句 实现 了 类 似 于 框架 的 网 页 嵌 套 技术 。 
其 中 ， 应 用 switch 语句 ， 根 据 变量 标识 $htgl 提交 的 值 进行 判断 ， 应 用 include 包含 语句 调用 不 同 功能 
模块 的 脚本 文件 。 代 码 如 下 : 

例 程 13 ”代码 位 置 ， 光盘 \TM\05\online_ks\admin\index.php 


<?php 
switch($htgD) { // 判 断后 台 超 链接 名 称 
case "考生 信息 管理 ": /如 果 名 称 为 “考生 信息 管理 ” 
include("ksxx_gl.php"); // 则 应 用 include0 语 名 调用 ksxx_gl.php 文 件 
break; // 退 出 语句 段 的 执行 
case "考题 类 别管 理 ": /如 果 名 称 为 “考题 类 别管 理 ” 
include("ktlb_gl.php"); // 则 应 用 include0 语 句 调用 ktlb_gl.php 文 件 
break; // 退 出 语句 段 的 执行 
case "考题 信息 添加 ": // 如 果 名 称 为 “考题 信息 添加 ” 
include("ktxx_tj.php"); // 则 应 用 include0 语 句 调用 ktxx_tj.php 文 件 
break; // 退 出 语句 段 的 执行 
case "考题 信息 管理 ": // 如 果 名 称 为 “考题 信息 管理 ” 
include("ktxx_gl.php"); // 则 应 用 include0 语 句 调用 ktxx_gl.php 文 件 
break; // 退 出 语句 段 的 执行 
} 
入 


5.9 ”考题 信息 管理 模块 设计 


5.9.1 考题 信息 管理 模块 的 概述 


考题 信息 管理 模块 主要 包括 查询 考题 信息 、 添 加 考题 信息 、 修 改 考 题 信息 和 删除 考题 信息 等 4 个 
功能 。 考 题 信息 管理 模块 的 框架 如 图 5.25 所 示 。 


Sn 
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考题 信息 管理 


| “天 on 革 题 让 | 修改 考 是 信息 | | | 开除 考 是 信息 | | 


| ns | 


525 ”考题 信息 管理 模块 的 框架 图 
5.9.2 ”考题 信息 管理 模块 的 技术 分 析 


在 实现 考题 信息 管理 模块 时 ， 为 了 更 好 地 管理 ， 因 此 把 考题 类 别 单独 存储 于 一 个 数据 表 tb_lb 中 ， 
这 样 在 录入 考题 信息 时 就 可 以 把 考题 类 别 以 下 拉 列 表 的 形式 从 数据 库 中 读 取出 来 。 这 种 从 下 拉 列 表 中 
动态 显示 数据 表 某 列 的 字段 值 的 方法 ， 不 仅 方便 管理 员 更 快捷 、 灵 活 地 操作 网 络 在 线 考试 系统 ， 更 大 
大 提高 了 工作 效率 ， 达 到 事半功倍 的 效果 。 

下 拉 列 表 是 一 种 最 节省 空间 的 数据 显示 方式 ， 正 常 状态 下 只 能 看 到 一 个 选项 ， 单 击 控制 按钮 后 
可 以 显示 一 定数 量 的 选项 ， 如 果 超 出 这 个 数量 ， 会 自动 显示 滚动 条 ， 管 理 员 可 以 通过 拖 动 深 动 条 来 选 
择 各 选项 。 

下 面 介绍 从 下 拉 列 表 中 动态 显示 数据 表 某 列 的 字段 值 的 方法 。 

首页 ， 创 建 与 数据 库 的 连接 。 代 码 如 下 : 

<?php 

$id=mssql connect('localhost','sa’,”"); 

mssql select db("db online ",$id); 

> 

然后 应 用 下 拉 列 表 框 和 select 查询 语句 相 结合 实现 在 下 拉 列 表 中 显示 数据 表 中 的 online_ktlb 字段 
的 值 ， 通 过 while 循环 语句 进行 输出 。 代 码 如 下 : 


<?php 
$query=mssql_query("select * from tb_ktlb"); /查询 考题 类 别 表 中 的 信息 
while($myrow=mssql_fetch_array($query)){ /应 用 while 循 环 语句 输出 考题 信息 
> 
< 输出 考题 类 别 表 中 的 online ktlb 字 段 -一 一 一 一 一 一 一 一 一 一 一 一- 一 一 > 
<option value="<?php echo $myrow[online_ktlb];?>"><?php echo $myrow[online_ktlb]:;?></option> 

<?php 

} /while 循 环 语句 结束 


5.9.3 ”考题 信息 添加 的 实现 过 程 


国 ”添加 考试 题目 信息 使 用 的 数据 表 : tb_Lesson、tb_taoTi 和 tb_Questions 
考试 题目 添加 包含 两 个 步骤 : 一 是 为 添加 的 考试 题目 选择 专业 、 课 程 以 及 套 题 ， 二 是 将 填写 的 考 
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考题 类 别 PHP 上 机 考题 到 所 属 套 题 [第 一 套 题 下 “| 考题 类 型 | 单 逻 可 分 数 [20 


去 拓 宇 行 串 至 入， 使 用 加 下 哪个 函数 7 = 
洪 加 考题 内 容 
| 
TE * 日 1trin() 国 数 * C rtrin() 函 数 * D ntrin() 函 司 
考题 答案 
加 选择 题 请 使 用 * 分 隔 答案 
FermOoB 归 “加 
考题 正确 答案 


司 选择 题 请 使 用 * 分 隔 答案 


图 5.26 考题 信息 添加 页 面 的 运行 结果 


考题 信息 添加 页 面 涉及 到 的 HTML 表单 的 重要 元 素 如 表 5.8 所 示 。 


表 5.8 
名 称 类 型 
form2 form 
kt_lb select 


考题 信息 添加 页 面 涉及 到 的 HTML 表单 的 重要 元 素 
重要 属性 含 


method="post” action="ktxx tj ok.php” 表单 


php 
$query=mssql_query(“select * from tb_ktlb™); 
while($myrow=mssql_fetch_array($query)){ 
> 
<option value= "<?php echo $myrow[online_ktlb];?>"> 
<?php echo $myrow[online_ktlb]:?> 
</option> 
< 2> 


考题 类 别 
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名 称 类 型 重要 属性 合议 
<select> 
<option value=" 第 一 套 题 "> 第 一 套 题 </option> 
<option value=" 第 二 套 题 "> 第 二 套 题 </option> 
Kena 人 <option value=" 第 三 套 题 "> 第 三 套 题 </option> 所 属 套 题 
<option value=" 第 四 套 题 "> 第 四 套 题 </option> 


</select> 
<select> 
<option value="2"> 简 答 </option> 
<option value="3"> 论 述 </option> 四 
kt_1x Select 人 考题 类 型 


<option value="0"> 单 选 </option> 
<option value="1"> 多 选 </option> 


/select> 
kt fs text size="10" 考试 成 绩 
kt nr textarea 考题 内 容 
kt_daan textarea 考题 答案 
kt _zqdaan textarea Cols="60" rows="5" 考题 正确 答案 
Submit2 Submit value=" 提 交 考题 " “提交 考题 ”按钮 


添加 考试 题目 首先 要 选择 考题 的 类 别 ， 然 后 所 择 所 属 套 题 ， 再 选择 考题 类 型 ， 其 实现 过 程 在 表 5.8 
所 示 的 表单 的 重要 属性 里 给 出 了 完整 的 代码 ， 这 里 不 再 次 述 ,最 后 根据 考题 类 别 将 考题 内 容 添加 完整 。 

提交 考题 表单 到 数据 处 理 页 ， 程 序 处 理 页 面 首先 应 用 变量 获取 到 表单 数据 ， 然 后 应 用 insert...into 
语句 将 其 插入 到 考题 信息 表 tb_kt 中 。 如 果 考 题 信息 添加 成 功 ， 则 弹出 提示 信息 ， 并 重新 定位 到 考题 信 
息 添加 页 面 。 数 据 处 理 页 的 完整 代码 如 下 : 

例 程 14 ”代码 位 置 ， 光 盘 \TM\05\online_ks\admin\ktxx_tj_ok.php 


<?php 
include("../conn/conn.php"); // 连 接 数 据 库 文 件 
if($Submit2 一 "提交 考题 "){ // 如 果 单 击 了 “提交 考题 ”按钮 ， 则 执行 下 面 语句 
$queryes=mssql_query("insert into tb_kt 
(kt Ib,kt lx,kt fs,kt nr,kt daan,kt zqdaan,kt small Ib)values('$kt Ib',$kt lx',$kt fs',$kt nr,'$kt daan','$kt zqdaan','$kt small 


Ib)"); // 向 考题 信息 表 中 添加 数据 
if($queryes){ // 如 果 添 加 操作 成 功 ， 则 弹出 提示 ， 并 重 定向 网 页 
echo "<script>alert(' 考 题 添加 成 功 ! '); window.location.href="index.php?htgl= 考 题 信息 添加 ';</script>"; 
b 
J 


5.9.4 ”查询 考题 信息 的 实现 过 程 


国 ”查看 考试 题目 列表 使 用 的 数据 表 : tb_kt、tb_ktlb 
管理 员 登 录 后 ， 单 击 “ 考 题 信息 管理 ” 超 链接 ， 进 入 到 查询 考题 信息 页 面 ， 选 择 考 题 类 别 后 ， 单 
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击 “ 考 题 查 找 ” 按 钮 ， 将 查询 出 该 类 别 下 的 所 有 考题 信息 。 同 时 提供 修改 考题 信息 和 删除 考题 信息 的 
功能 。 查 询 考题 信息 页 面 的 运行 结果 如 图 5.27 所 示 。 


考生 信息 管理 | 考题 类 别管 理 | 考题 信息 添加 | 考题 信息 管理 
| 1 t 


会 在 线 考 试 系统 后 各 管理 >》 考题 信息 管理 


考题 类 别 | | 考题 查 所 
考题 类 别 | EXR | /做 所 
去 掉 宇 符 串 两 边 的 空格 ， 使 用 如 下 哪个 函数 了 S| 
考题 内 容 | 
置 
Do | trin() 函 数 * B ltrin() 画 数 * C rtrin() 画 数 * D ntrin() 务 数 到 | /有 | 
到 
trin0 国 表 国 
考题 正确 答案 
| 


5.27 查询 考题 信息 页 面 的 运行 结果 
查询 考题 信息 页 面 涉及 到 的 HTML 表单 的 重要 元 素 如 表 5.9 所 示 。 
表 5.9 查询 考题 信息 页 面 涉及 到 的 HTML 表单 的 重要 元 素 


重要 属性 含义 

method="post" action="index.php?htgl= 考 题 信息 管理 " 查询 考题 表单 
<select name= "kt lb" id="kt_ lb"> 
<?php 
$query=mssql_query("select * from tb_ktlb"); 
while($myrow=mssql_fetch_array($query)){ 
> 考题 类 别 

<option value="<?php echo $myrow[online_ktlb];?>"> 
<2php echo $myrow[online_ktlb];?></option> 
<2php }2> 
</select> 


value=" 考 题 查 找 " “考题 查找 ”按钮 


名 称 类 型 


forml form 


Submit Submit 
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续 表 
名 称 类 型 重要 属性 含义 
form2 form method="post" action="ktxx_gl_ok.php" 考题 信息 表单 
kt lb text value="<?php echo Smyrow[kt lb]:?>" 考题 类 别 显示 
kt lx text value="<?php echo Smyrow[kt lx]:?>" 考题 类 型 
kt fs text value="<?php echo Smyrow[kt fs];?>" 考试 成 绩 
kt_id hidden value="<?php echo $myrow[kt_id]?>" 考题 类 别 id 
Submit2 submit value=" 修 改 " “修改 ”按钮 
Submit3 Submit value= "删除 " “删除 ”按钮 
kt nr textarea <?php echo Smyrow[kt nr]:;?> 考题 内 容 
kt_daan textarea <?php echo Smyrow[kt_daan];?> 考题 答案 
kt_zqdaan textarea <?php echo Smyrow[kt_zqdaan]:?> 考题 正确 答案 


在 考试 题目 查询 页 面 中 ， 首 先 建立 用 于 查询 的 表单 forml ， 该 表单 中 包含 “考题 类 别 ” 列 表 /菜单 
控件 以 及 “考题 查找 ”按钮 。 

当 管理 员 选 择 考 题 类 别 后 ， 单 击 “ 考 题 查找 ”按钮 ， 提 交 考 题 kt_lb 类 别 到 当前 页 ， 然 后 根据 获取 
到 的 考题 类 别 检索 考题 信息 表 tb_kt， 并 将 该 类 别 下 的 所 有 考题 信息 输出 到 浏览 器 。 代 码 如 下 

例 程 15 ”代码 位 置 ， 光盘 \TM\05\online_ks\admin\ktxx_gl.php 


一 一 一 考题 信息 显示 -一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一- -> 

<table width="682" height="168" border="0" cellpadding="0" cellspacing="1" bgcolor="#5D554A"> 

<?php 

include("../conn/conn.php"); // 连 接 数 据 库 文件 
© $query=mssql_query("select * from tb_kt where kt_ lb='$kt_ Ib"™); // 根 据 选 择 考 题 类 别 检索 数据 信息 
@ while($myrow=mssql_fetch_array(Squery)){ /将 查询 结果 应 用 while 循 环 输出 

> 

<form name="form2" method="post" action="ktxx gl ok.php"> 

<tr> 
< 一 一 一 一 一 -一 一 一- 一 一 一- 一 考题 类 别 显示 -一 -一 一 一 一 一 一 一 一 一 一 一 一 -一 -一 -一 -~ > 


<td width="112" height="27" align="center" bgcolor="#DDDDDD"> 考 题 类 别 </td> 
<td width="117" align="center" bgcolor="#DDDDDD"> 

<input name="kt lb" type="text" value="<?php echo Smyrow[kt lb];?>" size="8"> 
</td> 


width="180" align="center" bgcolor="#DDDDDD"> 考 题 类 型 
<input name="kt lx" type="text" value="<?php echo Smyrow[kt lx];?>" size="10"> 
</td> 


a width="148" align="center" bgcolor="#DDDDDD"> 分 数 

<input name="kt fs" type="text" value="<?php echo Smyrow[kt fs];?>" size="5"> 
</td> 
< 一 一 -建立 考题 ID 隐 藏 域 ， 添 加 “修改 ”、“ 删 除 ” 按 钮 -一 --- ~ > 
<td width="99" rowspan="4" align="center" bgcolor="#FFFFFF"> 

<input type="hidden" name="kt id" value="<?php echo Smyrow[kt id]?>"> 

<input type="submit" name="Submit2" value=" 修 改 ">/<input type="submit" name="Submit3" value=" 删 除 "> 
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<tr> 
<td height="43" align="center" bgcolor="#DDDDDD"> 考 题 内 容 </td> 
<td colspan="3" align="center" bgcolor="#FFFFFF"><textarea name="kt_ nr" cols="60" rows="5"><?php echo 
Smyrow[kt_nr];?></textarea></td> 
</tr> 
~ 
<tr> 
<td height="46" align="center" bgcolor="#DDDDDD"> 考 题 答案 </td> 
<td colspan="3" align="center" bgcolor="#FFFFFF"><textarea name="kt_daan" cols="60" rows="5"><?php echo 
$myrow[kt_daan];?></textarea></td> 
</tr> 


六 二 司 直 区 和 铬 业 量 示 二 二 到 
<tr> 
<td height="33" align="center" bgcolor="#DDDDDD"> 考 题 正 确 答案 </td> 
<td colspan="3" align="center" bgcolor="#FFFFFF"><textarea name="kt_zqdaan" cols="60" rows="5"><?php echo 
Smyrow[kt_zqdaan];?></textarea></td> 
</t> 
</form> 


<?php 
} //while 循 环 语句 结束 


> 
</table> 


Ah 代码 贴 二 


@ mssql_query() 函 数 : 向 SQL Server 服务 器 中 的 当前 活动 数据 库 发 送 一 条 SQL 查询 。 
@ mssql_fetch_array() 函 数 : 返回 根据 从 结果 集 获取 的 行 生成 的 数组 ， 如 果 没 有 更 多 行 则 返回 false。 语 法 如 下 : 


和 二 


array mssql_fetch_array( resource result [, int result_type] ) 

参数 result: 资源 类 型 的 参数 ， 要 传 入 的 是 由 mssql_query() 函 数 返 回 的 “数据 指针 ”。 

参数 result_type: 可 选项 , 整数 型 参数 ,要 传 入 的 是 MSSQL ASSOC、 MSSQL_ NUM 和 MSSQL_BOTH 3 种 由 PHP 
定义 好 的 常数 之 一 ， 默 认 值 是 MSSQL_BOTH. 
(1) 用 MSSQL_ASSOC 只 得 到 关联 索引 。 
(2) 用 MSSQL_ NUM 只 得 到 数字 索引 。 
(3) 用 MSSQL BOTH 将 得 到 一 个 同时 包含 关联 和 数字 索引 的 数组 。 
查询 考题 信息 页 面 提供 了 修改 考题 信息 的 功能 ， 管 理 员 可 对 指定 的 考题 信息 进行 编辑 ， 单 击 “ 修 
按钮 后 ， 提 交 Submit2 表单 信息 到 数据 处 理 页 ktxx_gl_ok.php。 
例 程 16 ”代码 位 置 : 光盘 \TM\05\online_ks\admin\ktxx_gl]_ok.php 


只 


<?php 
include("../conn/conn.php"); // 连 接 数 据 库 文件 
if($Submit2—true){ // 如 果 单 击 了 “修改 ”按钮 ， 则 执行 下 面 语句 


/ 汪 交 光 交 娄 光 交 家 内 交 交 兴 交 交 家用 pdate 语 名 修改 考题 信息 ** 六 闪闪 闪闪 交 交 交 光 兴 / 


$querys=mssql_query("update tb_kt set 
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kt Jb=$kt 1b\kt_ Ix="$kt Ix',kt fs='$kt fs,kt_nr=Skt_nrkt_daan=Skt daan'kt_zqdaan='Skt_zqdaan where kt_id=Skt id"); 
/* xxxxxxxxxxxxsxxxxssxsx 划 果 考 题 信息 修改 成 功 ， 弹 出 提示 ， 并 重 定向 到 首页 xxsssxexxxsxxxxxxxwxxxxx xl/ 
这 $querys){ 
echo "<script>alert(' 考 题 更 新 成 功 ! ); window.location.href="index.php?htgl= 考 题 信 息 管理 ';</script>"; 
虹 


查询 考题 信息 页 面 提供 了 删除 考题 信息 的 功能 ， 管 理 员 可 对 指定 的 考题 信息 进行 删除 ， 单 击 “ 删 
除 ” 按 钮 后 ， 提 交 Submit3 表单 信息 到 数据 处 理 页 ktxx_gl_ok.php。 
例 程 17 ”代码 位 置 ， 光盘 \TM\05\online_ks\admin\ktxx_gl]_ok.php 


<2php 
include("../conn/conn.php"); // 连 接 数 据 库 文件 
这 $Submit3 一 true){ /如 果 单 击 了 “删除 ”按钮 ， 则 执行 下 面 语句 


/delete 语 名 删除 指定 的 考题 信息 x eee oe 家/ 
$query=mssql query("delete from tb kt where kt id=$kt id"™); 
让 突 灾 光裕 灾 灾 实 风灾 光裕 灾 光 实 网 交加 果 考 题 信息 删 除 成 功 ， 弹出 提示 ， 上 :ED */ 


if($query){ 
echo "<script>alert(' 考 题 类 别 删 除 成 功 ! ); window.location.href="index.php?htgl= 考 题 信 息 管理 ';</script>"; 


} 


} 
> 


5.10 ”开发 技巧 与 难点 分 析 


5.10.1 考生 登录 编号 的 获取 


考生 登录 编号 的 生成 主要 应 用 的 是 mt_rand0 函 数 和 substr() 函 数 。 首 先 通过 mt_rand() 函 数 来 获取 
一 个 100000 一 999999 之 间 的 随机 数 ， 然 后 应 用 substr() 函 数 从 该 随机 数 中 获取 6 个 数字 ， 作 为 考生 
编号 。 

mt_rand() 函 数 的 功能 是 获取 随机 数 的 值 。 语 法 格式 如 下 : 


int mt_rand([int min,int max]) 


[ED 说 明 : 如 果 mt_rand() 函 数 没有 提供 可 选 参 数 min 和 max， 则 返回 0 到 RAND_MAX 之 间 的 伪 随 
机 数 。 


下 面 应 用 mt_rand() 函 数 来 获取 100000 一 999999 之 间 的 随机 数 。 代 码 如 下 : 
<?php echo mt_rand(100000,999999); ?> 


运行 结果 为 : 321864 
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5.10.2 通过 Ajax 技术 实现 计时 与 显示 剩余 时 间 


通过 Ajax 技术 实现 计时 与 显示 剩余 时 间 首先 要 创建 一 个 XMLHttpRequest 对 象 实例 ， 确 保 其 能 
在 所 有 支持 XMLHttpRequest 的 浏览 器 中 运行 ,将 其 代码 保存 在 一 个 名 称 为 xmlHttpRequestjs 的 文件 中 ， 
然后 在 需要 应 用 Ajax 技术 的 页 面 中 ， 应 用 以 下 代码 包含 该 文件 。 

<Script type="text/javascript" Src="js/xmlHttpRequestjs"></script> 
xmlHttpRequestjs 文件 的 代码 如 下 : 

例 程 18 ”代码 位 置 ， 光盘 \TM\WOS\online ksijsxmlHttpRequest.js 


var xmlHttp = false; // 创 建 一 个 布尔 型 变量 ， 用 来 检测 是 否 为 合法 的 正 实例 
try{ // 检 测 是 否 使 用 的 是 下 
xmlHttp = new ActiveXObject("Msxml2.XMLHTTP"); /如 果 JavaScript 的 版 本 大 于 5 
} catch (e) { // 如 果 不 是 ， 则 使 用 老 版 本 的 ActiveX 对 象 
try{ 1/ 如果 使 用 的 是 正 浏览 器 
xmlHttp = new ActiveXObject("Microsoft. XMLHTTP"); 
} catch (e2) {} 


} 
让 来 素来 来 束 素 来 束 素来 束 素 来 束 来 二 六 让 加 果 使 用 的 是 非 正 浏览 器 站 则 创建 一 个 该 对 象 的 JavaScript 实 例 *** 于 来 来 玉 玉 六 六 于 于 半球 */ 
if (IxmlHttp && typeof XMLHttpRequest != "undefined") { 
try{ 
xmlHttp = new XMLHttpRequest(); 
}catch(e3){ xmlHttp = false;} 
} 
接 下 来 编写 两 个 自 定义 的 JavaScript 函数 ShowTime() 和 sparetime()， 通 过 ShowTime() 函 数 读 取 显 
示 时 间 文 件 ShowTime.php 中 的 数据 ; 通过 sparetime() 函 数 读 取 获 取 剩余 时 间 文 件 sparetime.php 中 的 数 
据 。ShowTime() 和 sparetime() 函 数 的 代码 如 下 : 
例 程 19 ”代码 位 置 ， 光盘 \TM\05\online_ks\jsxmlHttpRequest.js 


<script type="text/javascript"> 


timer = window.setInterval("ShowTime()",1000); // 每 隔 一 秒 钟 调用 一 次 ShowTime() 函 数 
/定义 ShowTime() 函 数 以 通过 xmlHttpRequest 对 象 读 取 ShowTime.php 文 件 中 的 数据 
function ShowTime(){ 
xmlHttp.open("post","showtime.php", true); // 以 post 方 法 发 送 一 个 新 请 求 
xmlHttp.onreadystatechange = function(){ 
if(xmlHttp.readyState == 4){ // 如 果 服 务 器 响应 发 出 的 请 求 ， 则 执行 以 下 操作 
tet = xmlHttp.responseText; // 获 取 返 回 的 响应 信息 


/中 六 兴 当 六 闪 六 兴 六 闪 术 不 站 六 站 半 站 丰 不 相交 获取 到 | 的 信息 赋予 指定 的 DIV 标 记 术 于 下 下 来 玉 来 六 来 来 来 于 六 于 六 六 站 六 来/ 
document.getElementById("show time").innerHTML = tet; 
4 


上 

xmlHttp.send(null); // 发 送 请 求 
</script> 

<script type="text/javascript"> 


NS 
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time = window.setInterval("sparetime()",1000); // 每 隔 一 秒 钟 调用 一 次 sparetime() 函 数 
人 ####### 站 定义 sparetime() 函 数 以 通过 xmlHttpRequest 对 象 读 取 sparetime php 文 件 中 的 数据 # 相 ### 呈 下/ 
function sparetime(){ 
xmlHttp.open("post","sparetime.php", true); // 以 post 方 法 发 送 一 个 新 请 求 
xmlHttp.onreadystatechange = function(){ 
if(xmlHttp.readyState — 4){ // 如 果 服 务 器 响应 发 出 的 请 求 ， 则 执行 以 下 操作 
tet = xmlHttp.responseText; // 获 取 返 回 的 响应 信息 


人 让 站 训 中 下 中 中叶 中 站 让 焙 相 本 站 中叶 站 本 二 站 站 阁 站] 取 到 的 信息 赋予 指定 的 DIV 标 记 坟 * 玉 六 六 六 六 来 六 六 六 六 闪闪 六 浆 灾 冰 闪 六 浆 素 冰 */ 
document.getElementById("sparetime").innerHTML = tet; 


if(tet—"00:00"){ // 判 断 当 剩余 时 间 为 00:00 时 
form1.submit(); // 提 交 form1 表 单 中 的 数据 
是 
} 
xmlHttp.send(null); // 发 送 请 求 
</script> 


在 ShowTime.php 文件 中 实现 当前 时 间 的 显示 。 实 现 的 原理 是 : 获取 一 个 在 session 变量 中 存储 的 
考试 开始 时 间 的 时 间 戳 ， 然 后 再 应 用 mktime(O 函 数 获 取 当 前 时 间 的 时 间 戳 ， 应 用 当前 时 间 戳 减 去 考试 
开始 时 间 的 时 间 戳 ， 最 后 应 用 date(0) 函 数 输出 获取 的 新 时 间 戳 的 时 间 值 。 代 码 如 下 : 

例 程 20 ”代码 位 置 ， 光盘 \TM\05\online_ks\ShowTime.php 


<?php session_start(); /初始 化 session 变 量 
header('Content-Type: text/xml); 
$dates=$_ SESSION[dates]; /获取 session 变 量 中 存储 的 考试 开始 时 间 时 间 蕉 
$dates2=mktime(); // 获 取 系统 当前 时 间 的 时 间 截 
$dates3=$dates2-$dates; // 应 用 当前 时 间 的 时 间 截 减 去 考试 开始 时 间 的 时 间 惟 
echo date("i:s", $dates3); /| 输出 得 出 的 时 间 

> 


在 sparetime.php 文件 中 获取 考试 的 剩余 时 间 。 实 现 的 原理 是 : 首先 设置 考试 时 间 为 20 分 钟 ， 在 考 
试 开 始 时 间 的 基础 上 加 上 20 分 钟 , 然后 用 考试 时 间 减 去 系统 的 当前 时 间 , 获取 的 就 是 考试 的 剩余 时 间 ， 
当 剩 余 时 间 为 00:00 时 表示 本 次 考试 结束 ， 将 考试 题 自动 提交 。sparetime.php 文件 的 代码 如 下 : 

例 程 21 ”代码 位 置 ， 光 盘 \TM\05\online_ks\sparetime.php 


<?php session_start(); // 初 始 化 session 变 量 
header(Content-Type: text/xml); 
$dates=$_ SESSION[dates]; /获取 session 变 量 中 存储 的 考试 开始 时 间 蕉 
$dates1=$dates+1*60: // 设 定 考试 时 间 
$dates2=mktime(); /| 获取 系统 的 当前 时 间 截 
$dates3=$dates1-$dates2; /1/ 计 算 考试 的 剩余 时 间 
echo date("i:s",$dates3); /| 输出 考试 的 剩余 时 间 
> 
最 后 在 考试 操作 页 面 中 通过 DIV 标签 来 输出 考试 时 间 和 剩余 时 间 。 代 码 如 下 : 
<div id="sparetime"></div> <!-- 输 出 考试 剩余 时 间 --> 
<div id="show_time"></div> <!-- 输 出 考试 时 间 --> 
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5.11 _ Aiax 无 刷新 技术 专题 


5.11.1 Ajax 概述 


Ajax 是 Asynchronous JavaScriptand XML 的 缩写 ， 意思 是 异步 的 JavaScript 与 XML。 

Ajax 并 不 是 一 种 新 技术 , 或 者 说 它 不 是 一 种 技术 , 实际 上 , 它 是 结合 了 Javascript、XHTML 和 CSS、 
DOM、XML 和 XSTL、XMLHttpRequest 等 编程 技术 以 新 的 强大 方式 组 合 而 成 ， 可 以 让 开发 人 员 构 建 
基于 PHP 技术 的 Web 应 用 ， 并 打破 了 使 用 页 面 重 载 的 惯例 。Ajax 包含 : 

(1) XHTML 和 CSS 技术 实现 标准 页 面 。 

(2) Document Object Model 技术 实现 动态 显示 和 交互 。 
(3) XML 和 XSLT 技术 实现 数据 的 交换 和 维护 。 

(4) XMLHttpRequest 技术 实现 异步 数据 接收 。 

(5) JavaScript 绑 定 和 处 理 所 有 数据 。 

Ajax 是 一 种 运用 浏览 器 的 技术 ， 它 可 以 在 浏览 器 和 服务 器 之 间 得 到 异步 通信 机 制 进行 数据 通信 ， 
从 而 允许 浏览 器 向 服务 器 获取 少量 信息 而 不 是 刷新 整个 页 面 。 


5.11.2 ”Ajax 的 优点 


Ajax 是 使 用 客户 端 脚本 与 Web 服务 器 交换 数据 的 Web 应 用 开发 方法 。 这 样 ，Web 页 面 不 用 打 断 
交互 流程 进行 重新 加 载 ， 就 可 以 动态 地 更 新 。Ajax 优点 如 下 : 

(1) 减轻 服务 器 的 负担 。 

Ajax 的 原则 是 “ 按 需 取 数 据 ”， 可 以 最 大 程度 地 减少 元 余 请 求 ， 从 而 减轻 对 服务 器 造成 的 负担 。 

(2) 无 刷新 更 新 页 面 ， 减 少 用 户 心理 和 实际 的 等 待 时 间 。 

“ 按 需 取 数 据 ” 的 模式 减少 了 数据 的 实际 读 取 量 。 如 果 说 重 载 的 方式 是 从 一 个 终点 回 到 原点 再 到 另 
一 个 终点 的 话 ( 如 图 5.28 所 示 ) ， 那 么 Ajax 就 是 以 一 个 终点 为 基点 到 达 另 一 个 终点 (如 图 5.29 所 示 ) 。 


7 oN 
多 @) (© 


图 5.28 ” 重 载 方式 图 5.29 Ajax 方式 

其 次 ， 即 使 要 读 取 较 大 的 数据 ， 也 不 会 出 现 白 屏 的 情况 。Ajax 使 用 XMLHTTP 对 象 发 送 请 求 并 得 
到 服务 器 响应 ， 在 不 重新 载 入 整个 页 面 的 情况 下 用 JavaScript 操作 DOM 最 终 更 新 页 面 ， 所 以 在 读 取 数 
据 的 过 程 中 ， 用 户 所 面 对 的 不 是 白 屏 ， 而 是 原来 的 页 面 状 态 ; 页 面具 有 接收 到 全 部 数据 后 才 更 新 相应 
部 分 的 内 容 ， 而 这 种 更 新 也 是 瞬间 的 ， 用 户 几乎 感觉 不 到 。 

(3) 带 来 更 好 的 用 户 体验 。 

(4) 把 部 分 服务 器 负担 的 工作 转交 给 客户 端 ， 利 用 客户 端 闲置 的 能 力 来 处 理 任务 ， 从 而 减轻 服务 
器 和 带宽 的 负担 ， 节 约 空间 和 宽带 租用 成 本 。 

\ 28 
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(5) 可 以 调用 外 部 数据 。 
(6) 是 一 种 基于 标准 化 并 被 广泛 支持 的 技术 ， 不 需要 下 载 插件 或 者 小 程序 。 
(7) 进一步 促进 Web 页 面 展 现形 式 与 数据 的 分 离 。 


5.11.3 Ajax 的 工作 原理 


传统 的 Web 模式 强制 用 户 进入 “提交 一 等 待 一 重新 显示 ”网 页 ， 用户 的 动作 总 是 与 服务 器 进行 同步 
思考 ， 客 户 在 网 页 上 的 操作 转化 为 HTTP 请 求 传 回 服务 器 ， 而 服务 器 接受 请 求 以 及 相关 数据 、 解 析 数 据 
并 将 其 发 送 给 相应 的 处 理 单元 后 , 将 返回 的 数据 转 成 HTML 页 返还 给 客户 ,而 当 服 务 器 处 理 数据 的 时 候 ， 
用 户 只 能 等 待 ， 每 一 步 操作 都 需要 等 待 服务 器 返回 新 的 网 页 。 由 于 每 次 应 用 的 交互 都 需要 向 服务 器 发 送 
请 求 ， 应 用 的 响应 时 间 就 依赖 于 服务 器 的 响应 时 间 ， 这 就 导致 了 用 户 页 面 的 响应 比 本 地 应 用 慢 得 多 。 

运用 了 Ajax 技术 的 Web 应 用 模型 ， 它 的 工作 原理 相当 于 在 客户 端 和 服务 器 端 之 间 添 加 了 一 个 中 
间 层 ， 称 为 Ajax 引擎 (采用 JavaScript 编写 ， 通 常 在 一 个 隐藏 的 框架 中 ) ， 实 现 了 与 服务 器 进行 异步 
思考 的 通信 和 能力， 从 而 使 用 户 从 请 求 /响应 的 循环 中 解脱 出 来 ， 向 服务 器 发 出 异步 请 求 ， 也 就 是 不 用 等 
待 服务 器 的 通信 。 所 以 用 户 不 用 再 打开 一 个 空白 窗口 ， 等 待 服务 器 完成 后 再 进行 响应 。Ajax 应 用 可 以 
仅 向 服务 器 发 送 并 取 回 必需 的 数据 ， 它 使 用 SOAP 或 其 他 一 些 基 于 XML 的 Web Service 接口 ， 并 在 客 
户 端 采用 JavaScript 处 理 来 自 服务 器 的 响应 。 因 为 在 服务 器 和 浏览 器 之 间 交 换 的 数据 大 量 减少 ， 所 以 
Web 站 点 看 起 来 是 即时 响应 的 。 同 时 很 多 的 处 理工 作 可 以 在 发 出 请 求 的 客户 端 机 器 上 完成 ， 所 以 Web 
服务 器 的 处 理 时 间 也 减少 了 。 

引入 Ajax 的 Web 模型 与 传统 的 Web 模型 比较 如 图 5.30 所 示 。 


图 5.30 传统 Web 应 用 模型 与 Ajax Web 应 用 模型 的 比较 
“289 。 g 
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5.11.4 Ajax 的 工作 流程 


使 用 Ajax， 用 户 可 以 创建 接近 本 地 桌面 应 用 的 直接 、 更 可 用 、 更 丰富 、 更 动态 的 Web 用 户 界面 。 
Ajax 内 部 工作 流程 如 图 5.31 所 示 。 


一 二 


Intemet 用 户 Web 客户 端 


多 eb 浏览 器 发 送 HTTP 请 求 给 服务 器 


多 eb 服务 器 格 请 使 用 HTML 和 JavaScript 响 应 


JavaScript 代 码 向 服务 器 发 送 不 可 见 调用 请 求 


服务 器 通过 发 送 
请 求 的 数据 进行 响应 

， 更 新 各 户 端 显示 的 
内 容 


JavaScript 根 据 响应 数据 更 新 Web 页 面 


图 5.31 Ajax 内 部 工作 流程 图 
5.11.5 ”Ajax 中 的 核心 技术 XMLHttpRequest 


Ajax 技术 中 最 核心 的 技术 就 是 XMLHttpRequest， 它 是 一 个 具有 应 用 程序 接口 的 JavaScript 对 象 ， 
能 够 使 用 超 文本 传输 协议 〈Http) 连接 一 个 服务 器 ， 是 微软 公司 为 了 满足 开发 者 的 需要 ， 于 1999 年 在 
IE 5.0 浏览 器 中 率先 推出 的 。 现 在 许多 浏览 器 都 对 其 提供 了 支持 ， 不 过 实现 方式 与 IE 有 所 不 同 。 

通过 XMLHttpRequest 对 象 ，Ajax 可 以 像 桌 面 应 用 程序 一 样 只 同 服务 器 进行 数据 层面 的 交换 ， 而 
不 用 每 次 都 刷新 页 面 ， 也 不 用 每 次 都 将 数据 处 理 的 工作 交 给 服务 器 来 做 ， 这 样 既 减 轻 了 服务 器 负担 又 
加 快 了 响应 速度 、 缩 短 了 用 户 等 待 的 时 间 。 

在 使 用 XMLHttpRequest 对 象 发 送 请 求 和 处 理 响应 之 前 ， 首 先 需 要 初始 化 该 对 象 ， 由 于 
XMLHttpRequest 不 是 一 个 W3C 标准 ， 所 以 对 于 不 同 的 浏览 器 ， 初 始 化 的 方法 也 是 不 同 的 。 

1. IE 浏览 器 

IE 浏览 器 把 XMLHttpRequest 实例 化 为 一 个 ActiveX 对 象 。 具 体 方法 如 下 : 

var http_request = new ActiveXObject("Msxml2.XMLHTTP"); 

或 者 

var http_request = new ActiveXObject("Microsoft. XMLHTTP"); 


Re 
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[| 说 明 :上 面 语法 中 的 Msxml2.XMLHTTP 和 MicrosoftXMLHTTP 是 针对 IE 浏览 器 的 不 同 版 本 而 进 
行 设 置 的 ， 目 前 比较 常用 的 是 这 两 种 。 
2. Mozilla、Safari 等 其 他 浏览 器 
Mozilla、Safari 等 其 他 浏览 器 把 它 实例 化 为 一 个 本 地 JavaScript 对 象 。 具 体 方法 如 下 : 
var http_request = new XMLHttpRequest(); 

为 了 提高 程序 的 兼容 性 ， 可 以 创建 一 个 跨 浏览 器 的 XMLHttpRequest 对 象 。 创 建 一 个 跨 浏览 器 的 
XMLHttpRequest 对 象 其 实 很 简单 ， 只 需要 判断 一 下 不 同 浏览 器 的 实现 方式 ， 如 果 浏 览 器 提供 了 
XMLHttpRequest 类 ， 则 直接 创建 一 个 实例 ， 和 否则 使 用 IE 的 ActiveX 控件 。 有 具体 代码 如 下 : 

if (window.XMLHttpRequest) { // Mozilla、Safari…… 

http_request = new XMLHttpRequest(); 


} else if (window.ActiveXObject) { // IE 浏 览 器 


try{ 
http_request = new ActiveXObject("Msxml2.XMLHTTP"); 


} catch (e) { 


try{ 
http_request = new ActiveXObject("Microsoft. XMLHTTP"); 


} catch (e) 全 
} 
} 
说明: 由 于 JavaScript 具有 动态 类 型 特性 ， 而 且 XMLHttpRequest 对 象 在 不 同 浏览 器 上 的 实例 是 兼 
容 的 ， 所 以 可 以 用 同样 的 方式 访问 XMLHttpRequest 实例 的 属性 的 方法 ,不 需要 考虑 创建 该 
实例 的 方法 是 什么 。 


5.12 本章 总 结 


至 此 ， 一 个 完整 的 网 络 在 线 考试 系统 已 经 全 部 完成 。 在 程序 的 开发 过 程 中 ， 采 用 了 switch 框架 ， 
使 整个 系统 的 设计 思路 更 加 清晰 。 同 时 ， 为 了 使 程序 更 加 人 性 化 ， 系 统 中 应 用 了 Ajax 技术 实现 在 线 考 
试 时 自动 计时 等 功能 。 希 望 读者 能 认真 学 习 ， 并 做 到 融会 贯通 。 


第 章 


物流 配送 信息 网 


( Apache+PHP+phpMyAdmin+MySQL 5.0 实现 ) 


物流 信息 化 是 指 物流 企业 运用 现代 信息 技术 对 物流 过 程 中 产生 的 全 部 或 部 分 
信息 进行 和 采集、 分 类 、 传 递 、 汇 总 、 坦 询 等 一 系列 处 理 活动 ， 以 实现 对 货物 流动 过 
程 的 控制 ， 从 而 降低 成 本 、 提 高 效益 的 管理 活动 。 

物流 企业 信息 化 的 目的 就 是 要 满足 企业 自身 管理 的 需要 和 不 同类 型 企业 在 物 
流 业 务 外 包 过 程 中 对 信息 交换 方 的 要 求 ， 也 就 是 通过 建设 物流 信息 系统 ， 提 高 信息 
流转 效率 ， 降 低 物 流 运 作成 本 。 

目前 我 国正 处 于 全 面 推 进 信息 化 的 进程 之 中 , 所 以 物流 领域 的 信息 化 已 成 为 一 
个 必然 。 物 流 信息 化 将 成 为 现代 物流 的 灵 殊 .将 是 现代 物流 发 展 的 必 经 之 路 。 

本 章 开发 的 物流 配送 信息 网 就 是 为 了 增强 企业 的 市 场 竞争 力 ,， 加 快 企业 的 信息 
化 进程 ， 使 企业 在 市 场 竞争 中 立 于 不 败 之 地 。 通 过 阅读 本 章 ， 可 以 学 习 到 : 


物流 配送 系统 开发 的 基本 过 程 

如 何 创建 MySQL 数据 库 的 存储 过 程 

如 何 通过 MySQL 数据 库存 储 过 程 实现 用 户 登 录 
如 何 实现 数据 库 中 数据 的 模糊 查询 技术 

如 何 创建 浮动 框架 

如 何 实现 订单 的 打印 技术 


豆 吾 于 于 于 至 
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6.1 开发 青 景 


随 着 我 国信 息 化 进程 的 全 面 推进 ， 各 领域 的 信息 化 进程 都 在 飞速 的 发 展 ， 同 样 也 推动 着 物流 领域 
的 信息 化 进程 飞快 的 向 前 发 展 。 由 于 信息 化 进程 的 全 面 推进 ， 对 现代 物流 提出 更 高 的 要 求 : 信息 化 、 
自动 化 、 网 络 化 、 智 能 化 和 柔性 化 等 。 物 流行 业 的 竞争 日 益 激 烈 ， 客 户 需 求 的 标准 也 越 来 越 高 ， 物 流 
企业 要 想 在 市 场 中 占有 一 席 之 地 ， 必 须要 建立 一 个 高 效 、 快 捷 、 方 便 的 物流 信息 系统 ， 为 客户 提供 一 
流 的 服务 ， 并 且 能 够 及 时 准确 地 掌握 客户 的 需求 ， 对 客户 的 需求 做 出 快速 的 反映 ， 在 最 短 的 时 间 内 以 
最 大 限度 挖掘 和 优化 物流 资源 来 满足 客户 的 需求 ， 从 而 建立 高 效 的 数字 化 物流 经 济 。 


6.2 ”系统 分 析 


6.2.1 需求 分 析 


随 着 现代 物流 信息 化 进程 的 加 快 ， 传 统 的 物流 管理 方式 已 经 不 再 适应 当前 物流 发 展 的 要 求 ， 取 而 
代 之 的 将 是 以 计算 机 为 基础 的 网 络 化 物流 管理 方式 。 某 物流 配送 公司 为 适应 物流 信息 化 进程 的 发 展 ， 
急需 开发 一 个 物流 配送 系统 ， 通 过 网 络 来 实现 对 物流 操作 流程 进行 管理 ， 不 但 为 企业 的 运营 过 程 节省 
大 量 的 人 力 、 物 力 、 财 力 和 时 间 ， 提 高 物流 系统 运行 的 效率 ， 而 且 为 企业 在 客户 中 树立 一 个 全 新 的 形 
象 ， 为 企业 的 发 展商 定 一 个 良好 的 基础 。 现 根据 对 该 物流 配送 公司 的 实际 调查 ， 以 及 公司 的 具体 要 求 ， 
制定 出 物流 配送 信息 网 的 规划 方案 。 具 体内 容 如 下 : 
网 站 页 面 设计 要 求 美 观 大 方 ， 能 够 展示 企业 形象 。 
为 企业 在 客户 中 树立 一 个 全 新 的 形象 。 
网 站 的 操作 流程 简单 、 方 便 ， 能 够 提高 工作 效率 。 
提供 物流 配送 的 全 程 跟踪 。 
提供 配送 信息 的 及 时 查询 。 
实现 对 配送 车 辆 的 管理 。 
实现 对 客户 信息 的 管理 。 
实现 发 货 单 打印 的 功能 。 


办 办 办 办 办 办 欠 加 


6.2.2 可行 性 分 析 


物流 配送 信息 网 的 开发 不 但 能 使 物流 企业 走 上 科学 化 、 网 络 化 管理 的 道路 ， 而 且 能 够 为 企业 带 来 
巨大 的 经 济 效益 和 技术 上 飞速 的 发 展 。 

1. 经 济 性 

科学 的 管理 方法 ， 便 捷 的 操作 环境 ， 系 统 的 经 营 模 式 ， 将 为 企业 带 来 更 多 的 客户 资源 ， 树 立 企业 


的 品牌 形象 ， 提 高 企业 的 经 济 效益 。 
“#0. 


PHP 项 目 开发 全 程 实录 


2. 技术 性 

网 络 化 的 物流 管理 方式 ， 在 操作 过 程 中 能 够 快捷 地 查找 出 车 源 信息 、 客 户 订单 以 及 客户 信息 ; 能 
够 对 货物 进行 全 程 跟踪 ， 了 解 货物 的 托运 情况 ， 从 而 使 企业 能 够 根据 实际 情况 ， 做 好 运营 过 程 中 的 各 
项 准备 工作 ， 作 出 及 时 准确 的 调整 ， 能 够 保证 托运 人 以 及 收 货 人 对 货物 进行 及 时 的 处 理 。 


6.3 系统 设计 


6.3.1 系统 目标 


结合 目前 网 络 上 物流 配送 系统 的 设计 方案 ， 对 客户 做 的 调查 结果 以 及 企业 的 实际 需求 ， 本 项 目 在 
设计 时 应 该 满足 以 下 目标 : 
界面 设计 美观 大 方 、 操 作 简单 。 
功能 完善 、 结 构 清晰 。 
能 够 快速 查询 车 源 信息 。 
能 够 准确 填写 订单 。 
能 够 实现 订单 查询 、 打 印 。 
能 够 实现 对 回 单 处 理 。 
能 够 对 车 源 信息 进行 添加 、 修 改 和 删除 。 
能 够 对 客户 信息 进行 管理 。 
能 够 及 时 、 准 确 地 对 网 站 进行 维护 和 更 新 。 
良好 的 数据 库 系统 支持 。 
系统 运行 稳定 ， 具 备 良 好 的 防范 措施 。 


6.3.2 ”系统 功能 结构 
结合 需求 分 析 和 系统 目标 中 的 内 容 ， 物 流 配送 信息 网 的 功能 结构 已 经 设计 完成 。 为 了 使 读者 能 够 


更 清楚 地 了 解 网 站 的 结构 ， 下 面 给 出 物流 配送 信息 网 的 功能 模块 结构 图 和 工作 流程 图 。 
物流 配送 信息 网 的 功能 模块 结构 图 如 图 6.1 所 示 。 


因 办 办 办 办 办 办 办 办 凶 凶 


回执 单 确认 
添加 车 源 信息 
查询 车 源 信息 
修改 车 源 信息 
使 用 该 车 
删除 车 源 信息 


6.1 ”物流 配送 信息 网 功能 结构 图 
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物流 配送 信息 网 的 工作 流程 图 如 图 6.2 所 示 。 


货 动 到 送 货物 发 出 


图 6.2 物流 配送 信息 网 的 工作 流程 图 
6.3.3 ”系统 预览 


物流 配送 信息 网 由 多 个 程序 页 面 组 成 ， 下 面 给 出 儿 个 典型 页 面 ， 其 他 页 面 参见 光盘 中 的 源 程序 。 
物流 配送 信息 网 主页 如 图 6.3 所 示 ， 该 页 面 用 于 展示 本 系统 的 车 源 信息 查询 模块 。 登 录 页 面 如 图 6.4 
所 示 。 


PEI SONG XIN XI 
RS 2 ai 
Ei 
萄 流 贾 过 信息 网 
Dh 
Eee 
图 6.3 主页 (光盘 \TM\06\wlgl\indexs.php) 6.4 ”登录 页 面 ( 光 盘 \TM\06\wlglindex.php) 


回执 发 货 单 确认 模块 的 页 面 效果 如 图 6.5 所 示 , 该 页 面 主要 用 于 实现 对 回执 发 货 单 的 处 理 。 发 货 单 
查询 模块 的 页 面 效果 如 图 6.6 所 示 , 该 页 面 主要 用 于 实现 对 指定 发 货 单 的 查询 , 并 且 输 出 发 货 单 的 详细 


内 容 。 
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PE| SONG XIN XI Re PE SONG XIN 


图 6.5 回执 发 货 单 〈 光 盘 \TMVO6\wlglselect dhd.php) 6.6 发 货 单 查 询 (光盘 \TM\06Wwlgl\ hwys.php) 


车 源 信息 管理 模块 的 页 面 效果 如 图 6.7 所 示 ， 该 页 面 实现 对 车 源 信息 的 添加 、 修 改 和 删除 操作 。 修 
改 管理 员 密码 模块 的 页 面 效果 如 图 6.8 所 示 ， 该 页 面 实现 对 管理 员 密 码 的 修改 。 


PEI SONG XIN XI PEI SONG XIN XI 
> 0 2 


中 


图 6.7 车 源 信息 管理 (光盘 \TM\06\wlgl\car.php) ”图 6.8 修改 管理 员 密码 (光盘 \TM\06\ wlgl\update_pass.php) 


6.3.4 开发 环境 


在 开发 物流 配送 信息 网 时 ， 该 项 目 使 用 的 软件 开发 环境 如 下 : 
1. 服务 器 端 


操作 系统 : Windows XP Server/Linux (推荐 ) 。 
服务 器 : Apache 6.0。 

PHP 软件 : PHP 5.0。 

数据 库 : MySQL 5.0。 

MySQL 图 形 化 管理 软件 : PhpMyAdmin-6.9.0。 
开发 工具 : Dreamweaver 8。 

浏览 器 : IE 6.0 及 以 上 版 本 。 


办 办 办 办 办 多 
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加 


分 辨 率 : 最 佳 效 果 1024X768 像素 。 


2. 客户 端 
浏览 器 : IE 6.0 及 以 上 版 本 。 
分 辨 率 : 最 佳 效 果 1024X 768 像素 。 


6.3.5 文件 夹 组 织 结构 


在 进行 网 站 开发 之 前 ， 要 对 网 站 的 整体 文件 夹 组 织 架构 进行 规划 。 对 网 站 中 使 用 的 文件 进行 合理 
的 分 类 ， 分 别 放置 于 不 同 的 文件 夹 下 。 通 过 对 文件 夹 组 织 架构 的 规划 ， 可 以 确保 网 站 文件 目录 明确 、 
条 理 清晰 ， 同 样 也 便于 网 站 后 期 的 更 新 和 维护 。 物 流 配 送信 息 网 的 文件 夹 组 织 架 构 如 图 6.9 所 示 。 


日 久 “la 
om 连接 数据 库 的 文件 来 
加 “ss 存储 css 样式 文件 来 
国 inagss 一 一 存 佬 图 片 文件 的 文件 来 
四 js 一 一 一 一 一 一 一 一 一 一 — 存 针 肝 本 文件 的 文件 来 


图 6.9 文件 夹 组 织 结构 


6.4 数据 库 设 计 


物流 配送 信息 网 必须 拥有 数据 库 的 支持 ， 所 有 物流 配送 的 数据 都 应 该 存储 到 数据 库 中 ， 便 于 管理 
员 查 找 车 辆 、 订 单 和 客户 的 信息 。 如 果 没 有 数据 库 的 支持 ， 那 么 物流 配送 信息 网 将 没有 任何 意义 。 本 
节 将 对 物流 配送 信息 网 的 数据 库 设计 进行 详细 介绍 。 


6.4.1 数据库 分 析 

物流 配送 信息 网 是 一 个 中 小 型 的 企业 管理 系统 ， 考 虑 到 开发 的 成 本 、 搭 配 的 合理 性 以 及 操作 的 灵 
活性 等 ， 使 用 MySQL 数据 库 是 最 佳 的 选择 。MySQL 数据 库 是 完全 免费 的 ， 使 用 它 不 需要 任何 费用 ， 
可 以 直接 从 网 上 免费 下 载 ， MySQL 数据 库 的 操作 也 非常 方便 ， 不 但 可 以 在 命令 模式 下 操作 ， 而 且 配 备 
目前 比较 流行 的 图 形 化 管理 工具 phpMyAdmin， 能 够 轻松 地 实现 对 MySQL 数据 库 的 管理 和 操作 。 
6.4.2 ”数据库 概念 设计 


根据 上 述 各 节 对 物流 配送 信息 网 做 的 需求 分 析 和 系统 设计 ,整理 出 物流 配送 信息 网 的 实体 关系 E-R 
图 。 其 中 包括 管理 员 信息 实体 、 车 源 信息 实体 、 车 辆 日 志 信息 实体 、 客 户 信息 实体 和 发 货 单 信息 实 体 。 
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1. 管理 员 信 息 实体 
管理 员 信息 实体 用 于 存储 管理 员 的 登录 名 称 和 密码 信息 ， 包 括 用 户 名 和 密码 两 项 内 容 。 管 理 员 
息 实体 的 E-R 图 如 图 6.10 所 示 。 


用 户 名 管理 员 信 息 


图 6.10 管理 员 信息 实体 的 E-R 图 


理 


2. 车 源 信息 实体 
车 源 信息 实体 用 于 存储 企业 拥有 的 车 辆 信息 ， 包 括 车 主 姓名 、 车 主 身份 证 号 码 、 和 车牌 号码、 车 主 
联系 电话 、 车 主 的 家 庭 地 址 、 车 辆 行驶 的 路 线 和 车 辆 描述 。 车 源 信息 实 体 的 E-R 图 如 图 6.11 所 示 。 


车 主 家 庭 地 址 
车 主 身份 证 号 


车 辆 行驶 路 线 


图 6.11 车 源 信息 实体 的 E-R 图 


3. 车 辆 日 志 信息 实体 
车 辆 日 志 信息 实体 记录 车 辆 当前 是 否 被 占用 ， 以 及 使 用 的 时 间 、 执 行 的 任务 ， 包 括 车 牌号 码 、 车 
辆 日 志 信息 (详细 的 车 辆 使 用 描述 ) 、 日 志 时 间 和 发 货 单 ID《〈 即 执行 的 任务 ) 。 车 辆 日 志 信息 实体 的 


E-R 图 如 图 6.12 所 示 。 


图 6.12 车 辆 日 志 信息 实体 的 E-R 图 


车 辆 日 志 信息 


4. 客户 信息 实体 
客户 信息 实体 用 于 存储 客户 的 信息 ， 包 括 客户 的 姓名 、 客 户 电 话 和 客户 的 联系 地 址 。 客 户 信息 实 


体 的 E-R 图 如 图 6.13 所 示 。 
CC 客户 电话 [A | 一 CC 客 户 联系 地 址 > 


图 6.13 客户 信息 实体 E-R 图 


5. 发 货 单 信息 实体 
发 货 单 信息 实体 用 于 存储 客户 填写 的 发 货 单 信息 ， 包 括 车 牌号 码 、 车 主 电话 、 货 物 描 述 、 发 货 人 、 


Re 
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发 货 时 间 、 发 货 人 电话 、 发 货 地 址 、 收 货 人 、 收 货 人 电话 、 收 货 地 址 和 付款 方式 。 发 货 单 信息 实体 的 
E-R 图 如 图 6.14 所 示 。 


图 6.14 ”发 货 单 信息 实体 的 E-R 图 


6.4.3 创建 数据 库 及 数据 表 


在 物流 配送 信息 网 中 应 用 的 是 db_wlgl 数据 库 ， 其 中 涉及 5 个 数据 表 ， 如 图 6.15 所 示 。 
加 服务 器 : localhost ， 虽 数据 库 : db_wlgl 


表 类 型 整理 说 明 
th_admin MylSAM ”gb2312_chinese_ci 管理 员 信息 表 
tb_car MyISAM ”gb2312_chinese_ci 车 源 信 息 表 


th_car_log MyISAM ”gb2312_chinese_ci 车辆 日 志 信 息 表 
th_customer ”MyISAM ”gb2312_chinese_ci ”客户 信息 表 
tb_shopping MylSAM gb2312_chinese_ci 发 货 单 信息 表 
图 6.15 ”物流 配送 信息 网 的 数据 库 
下 面 介绍 物流 配送 信息 网 中 使 用 的 数据 表 ， 数 据 表 的 设计 结构 如 图 6.16~ 图 6.20 所 示 。 
1. tb_admin (管理 员 信 息 表 ) 
管理 员 信息 表 主 要 用 于 存储 管理 员 的 登录 名 和 密码 。 该 数据 表 的 结构 如 图 6.16 所 示 。 
困 服务 器 : localhost ， 马 数据 库 : db_wlgl ， 国 表 :tb_admin 


字段 类 型 整理 尾 性 Null 默认 额外 说 明 
这 int(10) 否 auto_increment 管理 员 信息 表 的 主键 
admin_user varchar(50) gb2312_chinese_ci 否 登录 名 称 
admin_pass varchar(50) gb2312_chinese_ci 否 登录 客 码 


图 6.16 管理 员 信息 表 结 构 
2. tb_car (车 源 信息 表 ) 
车 源 信 息 表 主 要 用 于 存储 配送 公司 拥有 的 车 辆 信息 ， 主 要 包括 车 主 姓名 、 车 主 身份 证 号 码 、 车 牌 
号 码 、 车 主 联系 电话 、 车 主 的 家 庭 地 址 、 车 辆 行驶 的 路 线 和 车 辆 描述 。 该 数据 表 的 结构 如 图 6.17 所 示 。 
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四 服务 器 : localhost ， 昌 数据 库 : db_wlgl * 国 表 :tb_car 


字段 类 型 整理 尾 性 Null 默认 禾 外 说 明 
过 intdo) 否 auto_increment 车 源 信息 表 的 主键 
username varchar(50) gb2312_chinese_ci 否 车 主 的 姓名 
user_number varchar(50) gb2312_chinese_ci 否 车 主 的 身份 证 号 码 
car_number varchar(50) gb2312_chinese_ci 否 车 牌号 码 
tel varchar(50) gb2312_chinese_ci 否 车 主 电 话 
address varchar(80) gb2312_chinese_ci 否 车 主 联系 地 址 
car_road mediumtext gb2312_chinese_ci 否 车 辅 行驶 路 线 
car_content mediumtext gb2312_chinese_ci 否 车 辆 描述 

图 6.17 车 源 信息 表 结 构 


3. tp_car_log (车 辆 日 志 信息 表 ) 
车 辆 日 志 信息 表 主 要 用 于 存储 车 辆 的 使 用 情况 信息 ， 主 要 包括 车 牌号 码 、 车 辆 使 用 日 志 、 日 志 创 
建 时 间 和 车 辆 执行 的 任务 。 该 数据 表 的 结构 如 图 6.18 所 示 。 
胃 服务 器 : localhost ， 电 数据 库 : db_wlgl 国 表 :tb_car_log 


字段 类 型 整理 尾 性 Null 默认 额外 说 明 
log id int(10) 否 auto_increment ”车 辆 日 志 表 的 ID 
car_number varchar(50) gb2312_chinese_ci 否 车 牌号 码 
car_log mediumtext gb2312_chinese_ci 否 车 辆 日 志 信 息 
log_date datetime 否 日 志 创建 时 间 
fahuo_id varchar(50) gb2312_chinese_ci 否 发 货 单 的 ID 


图 6.18 车 辆 日 志 信息 表 结 构 
4. tb_customer (客户 信息 表 ) 


客户 信息 表 主 要 用 于 存储 客户 的 信息 ， 包 括 姓名 、 电 话 以 及 联系 地 址 。 该 数据 表 的 结构 如 图 6.19 
所 示 。 


中 服务 器 :localhost ， 电 数据 库 : db_wlgl ， 国 表 :tb_customer 
字段 类 型 


整理 尾 性 Null 默认 额外 说 明 
customer id intt10) 否 auto_increment “客户 信息 表 的 ID 
customer_user varchar(50) gb2312_chinese_ci 否 客户 姓名 
customer_tel Varchar(50) gb2312_chinese_ci 否 客户 电话 
customer_address varchar(80) gb2312_chinese_ci 否 联系 地 址 


图 6.19 客户 信息 表 结构 
5. tb_shopping (发 货 单 信息 表 ) 
发 货 单 信息 表 主 要 用 于 存储 客户 填写 的 发 货 单 中 的 信息 ， 主 要 包括 车 牌号 码 、 车 主 电 话 、 货 物 描 
述 、 发 货 人 、 发 货 时 间 、 发 货 人 电话 、 发 货 地 址 、 收 货 人 、 收 货 人 电话 、 收 货 地 址 和 付款 方式 。 该 数 
据 表 的 结构 如 图 6.20 所 示 。 
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踢 服务 器 : localhost ， 昌 数据 库 : db_wlgl * 国 表 :tb_shopping 


字段 类 型 整理 尾 性 ”Null 葡 认 额外 说 明 
id int(10) 否 auto_increment ”发 货 单 信息 表 的 主键 ID 
car_number Yarchart50) gb2312_chinese_ci 否 车 牌号 码 
fahuo_content mediumtext gb2312_chinese_ci 否 货物 描述 
fahuo_id Yarchar(50) gb2312_chinese_ci 再 发 货 ID 
fahuo_user warcharf50) gb2312_chinese_ci 否 发 货 人 
fahuo_time datetime 发 货 时 间 
fahuo_ys yarchar(20) gb2312_chinese_ci 是 0 回 单 确认 
fahuo_fk Yarchar(20) gb2312_chinese_ci 否 付款 方式 
car_tel yarchar(50) gb2312_chinese_ci 否 车 主 电话 
Shouhuo_user warchar(50) gb2312_chinese_ci 否 收 货 人 
shouhuo_address mediumtext gb2312_chinese_ci 否 收 货 地 址 
fahuo_address mediumtext gb2312_chinese_ci 再 发 货 地 址 
fahuo_tel varchar(50) gb2312_chinese_ci 否 发 货 人 电话 
shouhuo_tel Yarchar(50) gb2312_chinese_ci 否 收 货 人 电话 


图 6.20 发 货 单 信 息 表 结构 
6.5 网 站 首页 设计 


6.5.1 网 站 首页 概述 


网 站 首页 是 整个 网 站 的 门面 ， 是 浏览 者 看 到 的 第 一 视觉 界面 ， 所 以 在 设计 网 站 的 首页 时 应 该 将 网 
站 中 主要 的 内 容 尽 量 展示 给 浏览 者 ， 让 浏览 者 能 够 更 快 地 了 解 网 站 的 内 容 。 物 流 配送 信息 网 的 首页 主 
要 包括 如 下 功能 : 
车 源 信息 查询 : 主要 实现 车 辆 信息 查询 ， 及 时 为 客户 选择 货物 配送 的 方案 。 
发 货 单 : 主要 用 于 客户 发 货 单 信息 填写 。 
回执 发 货 单 确认 : 主要 用 于 对 货物 配送 回执 单 的 确认 。 
发 货 单 查询 : 主要 用 于 对 发 货 单 进行 查询 。 
客户 信息 管理 : 主要 用 于 对 客户 的 信息 进行 管理 。 
车 源 信息 管理 : 主要 用 于 对 企业 拥有 的 车 辆 信息 进行 管理 。 
修改 密码 :主要 用 于 对 管理 员 登 录 的 密码 进行 修改 。 
下 面 看 一 下 本 案例 中 提供 的 网 站 首页 ， 该 页 面 在 本 书 光盘 中 的 路 径 为 \TM\06\wlglindex.php， 如 


图 6.21 所 示 。 
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物流 配送 信息 网 ， 信 誉 之 上 ， 努 力 打造 物流 品牌 


功能 模块 内 容 展示 


物流 配送 信息 网 版 权 所 有 网 站 必 文 作 | 


图 6.21 物流 配送 信息 网 首页 


6.5.2 ”网 站 首页 技术 分 析 


物流 配送 信息 网 是 为 物流 配送 公司 设计 的 一 个 物流 管理 系统 ， 其 页 面 的 设计 突出 简洁 、 方 便 ， 功 
能 的 实现 以 便于 操作 和 维护 为 根本 。 网 站 首页 的 页 面 设计 如 图 6.21 所 示 ， 由 一 个 简单 的 框架 组 成 ， 其 
结构 由 两 部 分 组 成 : 一 部 分 用 于 输出 网 站 中 包括 的 模块 ， 另 一 部 分 用 于 输出 对 应 模块 中 的 内 容 。 首 页 
框架 结构 如 图 6.22 所 示 。 


输出 功能 模块 的 内 容 


图 6.22 首页 框架 结构 


RS 
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这 里 使 用 的 框架 结构 不 是 frame 框架 ， 而 是 应 用 switch 语句 ， 加 上 表格 的 典 套 实现 的 框架 效果 。 
有 关 switch 语句 的 详细 应 用 可 以 参考 2.12.2 节 


6.5.3 ”网 站 首页 的 实现 过 程 


物流 配送 信息 网 的 首页 设计 非常 简单 ， 主 要 应 用 一 个 简单 的 框架 功能 ， 并 且 以 超 链接 作为 辅助 ， 
最 终 实 现在 不 同 功能 模块 之 间 的 跳 转 。 
例 程 01 ”代码 位 置 : 光盘 \TM\06\wlglindexs.php 
首先 连接 数据 库 , 判断 登录 用 户 的 身份 ,如果 是 管理 员 则 可 以 进入 网 站 进行 操作 ,否则 将 提示 “请 
您 正确 登录 ! ”， 并 且 跳 转 到 网 站 的 登录 页 面 。 关 键 代 码 如 下 : 


<2php session_start(); // 初 始 化 session 变 量 
include("conn/conn.php"); // 连 接 数 据 库 
if($_SESSION[admin_user]—true)!{ 1/ 判断 登录 用 户 的 身份 

> 

<!L--> 省 略 了 部 分 代码 <!-~ 

<?php 

yelse{ /没有 以 管理 员 登 录 ， 则 跳 转 到 登录 页 


echo "<script>alert(' 请 您 正确 登录 !"); window.location.href="index.php';</script>"; 
} 
> 


然后 设计 首页 中 使 用 的 模块 超 链接 ， 并 且 为 每 个 超 链接 定义 变量 标识 ， 当 单 击 不 同 功能 模块 超 链 
接 时 提交 不 同 的 变量 标识 ， 作 为 下 一 步 获取 模块 中 详细 内 容 的 依据 ;其 中 还 使 用 ononMouseOver 和 
onMouseOut 事件 ， 控 制 鼠 标 移动 到 和 离开 单元 格 时 显示 不 同 的 颜色 。 部 分 代码 如 下 : 


<tr onMouseOver="this.bgColor='#9FCB3A"onMouseOut="this.bgColor=#F5F5F5" > 
<td height="28" align="center">&nbsp;</td> 
< 设置 车 源 信息 查询 模块 的 超 链接 ， 变 量 标识 为 "Imbs= 车 源 信息 查询 "------------------ -> 
<td align="left"><a href="indexs.php?Imbs= 车 源 信息 查询 "> 车 源 信息 查询 </a></td> 
</t> 
<tr onMouseOver="this.bgColor=#9FCB3A"onMouseOut="this.bgColor=#F5F5F5" > 
<td 2 align="center">&nbsp;</td> 
二 设置 发 货 单 模块 的 超 链接 ， 变 量 标识 为 "lmbs= 发 货 单一- -> 
<td align="left"><a href="indexs.php?lImbs= 发 货 单 "> 发 货 单 </a></td> 


最 后 应 用 switch 语句 ， 根 据 变量 标识 Slmbs 提交 的 值 进行 判断 ， 使 用 include 包含 语句 调用 不 同 功 
能 模块 的 脚本 文件 。 关 键 代码 如 下 : 


<?php 
switch($lmbs){ // 获 取 变 量 Slmbs 的 值 
case "车 源 信息 查询 ": // 淹 断 当 变量 $lmbs 的 值 是 "车 源 信息 查询 "时 输出 下 面 的 内 容 
include("car_select.php"); // 调 用 指定 的 包含 文件 
break; /跳出 循环 
/这 里 省 略 了 部 分 代码 


“0. 
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case ™: // 判 断 当 变 量 的 值 为 宝 时 
include("car_select.php"); // 当 变量 的 值 为 空 时 则 调用 该 文件 
break; // 跳 出 循环 


6.6 车 源 信息 查询 模块 设计 


6.6.1 车 源 信息 查询 模块 概述 


车 源 信息 查询 模块 的 功能 是 根据 客户 提供 的 货物 配送 的 地 点 ， 从 数据 库 中 查询 有 关 该 路 线 的 车 辆 ， 
为 客户 提供 一 个 合理 配送 的 路 线 ， 最 后 确定 发 货 订 单 。 操 作 流 程 如 图 6.23 所 示 。 


图 6.23 车 源 信息 查询 的 操作 流程 


6.6.2 车 源 信息 查询 模块 技术 分 析 


车 源 信息 查询 模块 的 主要 功能 就 是 查询 车 辆 的 使 用 信息 ， 为 客户 提供 最 合适 的 货物 配送 路 线 。 
中 应 用 的 关键 技术 自然 就 是 查询 方法 ， 为 了 给 客户 提供 最 合适 、 最 满意 、 最 快捷 的 配送 服务 ， 这 里 使 
用 的 是 模糊 查询 技术 。 

通过 模糊 查询 技术 ， 只 要 客户 提出 配送 货物 的 出 发 地 点 和 到 达 地 点 ， 管 理 员 就 可 以 从 数据 库 中 提 
取出 所 有 与 该 路 线 相关 的 车 辆 信息 ， 包 括 车 辆 的 承载 能 力 、 车 辆 是 否 被 占用 和 车 辆 的 使 用 情况 ， 都 一 
目 了 然 ， 客 户 可 以 根据 实际 的 情况 〈 时 间 、 货 物 数量 、 路 线 等 ) 选择 车 辆 ， 确 认 后 填写 发 货 单 。 

模糊 查询 技术 的 实现 是 在 car_select.php 文件 中 完成 的 ， 首 先 要 与 数据 库 建 立 连 接 ， 然 后 创建 一 个 
form 表单 , 设置 两 个 文本 框 selectl 和 select2 用 于 提交 出 发 地 点 和 到 达 地 点 , 将 表单 的 值 提交 到 当前 页 ; 
最 后 编写 PHP 脚本 语句 ， 以 表单 中 获取 的 数据 为 条 件 ， 执 行 like 模糊 查询 ， 从 数据 库 的 指定 表 中 查询 
符合 条 件 的 信息 ， 并 且 将 查询 出 的 信息 显示 到 页 面 中 。 程 序 的 关键 代码 如 下 : 

例 程 02 ”代码 位 置 : 光盘 \TM\06\wlgl\car_select.php 


<2php 
\ 。304 。 
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session_start(); include("conn/conn.php"); // 连 接 数 据 库 
?> 
< 创建 form 表 单 ， 提 交 出 发 地 点 和 到 达 地 点 -一 一 -一 一 -一 -> 


<form id="form1" name="form1" method="post" action="indexs.php?lmbs= 车 源 信息 查询 " onSubmit="javascript: retum 
check_select_car();"> 
<td height="30" colspan="4" align="right" bgcolor="#FFFFFF"> 查 询 
© <input name="select1" type="text" id="select1" size="10"> 至 
© <input name="select2" type="text" id="select2" size="10"></td> 
<td colspan="2" bgcolor="#FFFFFF"><input type="submit" name="Submit" value=" 提 交 " /></td> 
</form> 
<!-- -一 ---------- 一 获取 表单 提交 的 值 ， 根 据 该 条 件 执行 like 模 糊 查 询 ， 从 数据 库 中 读 取 数 据 -------------------- -~ > 
<?php 
© if($select1==true || $select2—true)!{ // 判 断 表 单 提交 的 值 是 否 为 真 
i 六 迷 当 当 兴 六 六 六 闪闪 站 丰 丰 本 本 以 表单 提交 的 值 为 条 件 ， 从 数据 表 中 查询 数据 *** 六 六 六 六 六 六 六 六 率 半 闪闪 六 冰 */ 
上 $query="select * from tb_car where car_road like '%Sselect1%' and car_road like '% S$select2%"; 
$result=mysql_query( $query); // 执 行 查询 语句 
if(mysql_num_rows($result)>0){ // 判 断 是 否 存 在 符合 条 件 的 数据 
while($myrow=mysql_fetch_array( $result)){ // 应 用 while 循 环 语句 ， 输 出 符合 条 件 的 数据 


<tr> 

<td height="26" align="center" bgcolor="#FFFFFF"><?php echo $myrow[car_number];?></td> 

<td bgcolor="#FFFFFF"><?php echo $myrow[car_road];?></td> 

<td colspan="2" bgcolor="#FFFFFF"><?php echo $myrow[car_content];?></td> 

<td bgcolor="#FFFFFF"> 

<?php 
记 ssyty9t 根 据 车 牌号 码 ， 从 车 辆 日 志 信 息 表 中 读 取 对 应 车 辆 的 使 用 信息 yyyyysyy* */ 
$querys=mysql_query("select * from tb_car_ log where car_number='$myrow[car_number]'"); 
$myrows=mysql_fetch_array($querys); 


echo $myrows[car_log]; /| 输出 车 辆 的 使 用 日 志 信 息 

> 

</td> 

<td align="center" bgcolor="#FFFFFF"> 

<?php 

if($myrows[car_log]==nulD)!{ /判断 车 辆 日 志 是 否 为 室 ， 如 果 为 室 ， 则 执行 下 面 的 内 容 
echo "<a href='indexs.php?lmbs= 发 货 单 &ljid=$myrow[id]> 使 用 该 车 </a>"; 

jelsef // 如 果 车 辆 日 志 不 为 空 ， 则 执行 下 面 的 内 容 
echo "<a href='indexs.php?lmbs= 发 货 单 &ljid=$myrow[id]'> 预 定 该 车 </a>"; 

> 

<ltd> 


</tr> 
<?php }}else{ echo "您 查找 的 路 线 不 存在 1"; }}?> 


< 代码 贴 二 
@ selectl: 指定 出 发 地 点 。 
@ select2: 指定 到 达 地 点 。 
上 @ if 语 句 : 判断 从 表单 中 获取 的 变量 是 否 为 真 。 
@ like: 执行 模糊 查询 ， 从 数据 库 中 读 取 符 合 条 件 的 数据 。 
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6.6.3 ”车 源 信息 查询 模块 的 实现 过 程 


国 车 源 信息 查询 模块 使 用 的 数据 表 : tb_car、tb_car log 
车 源 信息 查询 模块 的 功能 是 根据 客户 提供 的 信息 ， 从 数据 库 中 读 取 有 关 某 个 路 线 的 车 辆 使 用 的 情 
形 ， 及 时 为 客户 确定 一 个 合理 的 物流 配送 方案 。 该 模块 的 运行 结果 如 图 6.24 所 示 。 


TC ET 
CE Via 
PEI SONG XIN Xl 
物流 配送 信息 网 ， 信 溢 之 上 ， 努 力 打造 物流 品牌 
| 
车 尖 信 息 查 齐 查询 [长 至 [Wm 提交 
八仙 单 EE Eo 3 全 用 B 志 是 否 使用 
加 所 发 货 间 确认 冯 和 -176745 | 发 春 -沈阳 -大 连 A EE oR Kat i 
发 间 查 询 pp pe 大 贡 , 直 3 6 后 站 本 (12 水 长 24 末 ， 人 
害 户 信息 管 理 pe ree 大 贡 革 , 直 色 3 8 水 , 后 直径 4 12 来 ,长 24 玉 , 请 时 
peg 商人 本 -大 证 疝 册 | 大 于 革 直 三 3 5 后 直 本 4 12 末 长 54 全 
个 密码 C3 


| 
| 
| 


志和 配送 信息 网 版 权 所 有 


6.24 ”车 源 信息 查询 模块 的 运行 结果 


车 源 信息 查询 功能 的 实现 通过 car_select.php 文件 来 完成 ， 首 先 与 数据 库 建立 连接 ; 然后 创建 一 个 
form 表单 ， 将 客户 的 地 址 信息 提交 到 当前 页 ， 作 为 查询 的 条 件 ， 最 后 编写 PHP 脚本 语句 ， 以 表单 中 获 
取 的 地 点 数据 为 条 件 ， 执 行 like 模糊 查询 ， 从 数据 库 的 指定 表 中 查询 符合 条 件 的 信息 ， 并 且 将 查询 出 
的 信息 显示 到 页 面 中 。 其 关键 代码 可 以 参考 例 程 02。 


6.6.4 ”单元 测试 


在 对 车 源 信息 查询 模块 进行 测试 的 过 程 中 ， 当 输入 指定 的 出 发 点 和 到 达 地 点 进行 提交 后 ， 出 现 如 
图 6.25 所 示 的 页 面 ， 程 序 出 错 ， 没 有 找到 符合 条 件 的 记录 。 


Sm 
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有 


nm 

发 货 单 F:\webpage\Tsoft\wlgel\car_select.php on line 31 
A 您 查 技 的 路 线 不 存在 | 
RN 人 EE 

3 | E99 | ET 便 用 日 志 是 否 全 用 
客户 信息 管理 
车 源 信 息 管 理 
3 


6.25 ”车 源 信息 查询 的 错误 运行 结果 


分 析 错 误 原因 : 从 弹出 的 错误 信息 来 看 ， 错 误 应 该 与 数据 库 有 关 。 下 面 从 数据 库 开始 查找 错误 的 
原因 ， 首 先 确 定 程序 中 使 用 的 数据 库 、 数 据 表 和 字段 的 书写 是 否 正 确 ， 仔 细 核 对 没有 发 现 问 题 ， 然 后 
确认 使 用 的 select 查询 语句 的 格式 是 否 正 确 , 经 检查 发 现 ， 在 编写 select 查询 语句 时 使 用 了 错误 的 语句 
格式 , 在 执行 like 模糊 查询 时 没有 将 参数 的 两 侧 加 上 单 引 号 (car_road like %S$select1% and car_road like 
%$select2%) ， 从 而 导致 程序 中 类 型 不 匹配 的 错误 。 其 错误 语句 和 正确 语句 的 对 比如 图 6.26 所 示 。 
gy ($selectl==true || $select2==true) { 

$query=" select + from tb_car where car_road| 
$result=nysal_query ($query) ; 


if (mysql_num_rows ($result)>0) { 
while ($nyrow=mysql_fetch_array ($result)) { 


like %$selectl% and car_road like %$select2%"; 


2> 
《?php 

if ($selectl==true || $select2==true) { 
Sery celect + fron tb cur where car_road[ WsoloctiN end cor coud ike Xieclectoy"] 
$result=nysql_query ($query) ; 

if (nysql_nun_rows ($result)>0) { 
while (Snyrow=nysql_fetch_array ($result)) { 

?> 


图 6.26 错误 语句 和 正确 语句 对 比 


正确 的 格式 为 car road like '%S$select1%' and car road like %$select2%'， 或 者 car_road like 
"%".$select1."%' and car_road like '%".$select2."%'。 修 改 后 保存 程序 ， 程 序 正常 运行 。 


全 注意 : 在 执行 SQL 语句 的 过 程 中 ， 传 入 SQL 语句 的 参数 为 字符 型 数据 ， 所 以 在 传 入 参数 的 两 侧 应 
该 加 上 单 引 号 ， 表示 该 数据 为 字符 型 ， 否 则 程序 将 发 生 类 型 不 匹配 的 错误 。 
[ED 说 明 : 在 PHP 中 的 字符 囊 有 两 种 表示 格式 : 第 一 种 是 将 字符 囊 用 单 引号 括 起 来 ， 第 二 种 是 将 字符 


串 用 双 引 号 括 起 来 。 如 果 采 用 第 二 种 格式 ，PHP 变量 可 以 直接 写 在 该 字符 串 中 ， 系 统 不 会 
将 该 变量 看 作 是 字符 串 的 一 部 分 ， 而 是 将 其 看 作 PHP 的 合法 变量 。 


6.7 ”发 货 单 管理 模块 设计 
6.7.1 发 货 单 管理 模块 概述 


发 货 单 管理 模块 主要 包括 发 货 单 的 填写 、 发 货 单 查询 、 发 货 单打 印 和 发 货 单 删除 。 发 货 单 管理 模 
“307。 
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块 的 主要 功能 如 图 6.27 所 示 。 


图 627 发 货 单 管理 模块 的 功能 结构 图 
6.7.2 发 货 单 管理 模块 技术 分 析 


如 何 才能 发 挥 函 数 的 最 大 作用 ?设计 者 不 但 要 能 够 从 表面 理解 函数 的 功能 和 作用 ， 而 且 要 能 够 以 
一 种 发 散 的 思维 方式 去 考虑 问题 ， 不 要 被 其 本 身 的 功能 所 束缚 ， 要 将 函数 中 某 些 功能 有 机 地 结合 起 来 ， 
从 而 发 挥 其 更 大 的 作用 。 

在 发 货 单 管理 模块 中 应 用 到 一 个 发 货 单 的 编号 ， 该 编号 是 发 货 单 的 唯一 标识 ， 不 允许 存在 重复 。 
在 编写 生成 这 个 编号 的 程序 时 ， 首 选 方案 是 应 用 随机 函数 获取 随机 的 数字 作为 编号 ， 这 是 一 个 最 直接 
的 做 法 ， 但 是 考虑 到 发 货 单 编号 不 但 具有 唯一 性 ， 而 且 还 要 使 其 具有 一 定 的 标志 性 ， 从 这 个 角度 考虑 
使 用 随机 函数 就 有 些 不 适合 ， 因 为 其 不 具备 一 定 的 标志 性 。 这 时 ， 如 果 应 用 date0) 函 数 则 可 以 达到 上 述 
所 说 的 要 求 ， 不 但 编号 具有 唯一 性 ， 而 且 还 有 规律 可 循 。 

为 了 能 够 更 好 地 理解 这 种 发 散 思维 的 编程 思想 ， 首 先 介 绍 一 下 date(0) 函 数 。 语 法 格式 如 下 : 


string date ( string format , int timestamp) 


该 函数 返回 将 参数 timestamp 按照 指定 格式 字符 串 而 产生 的 字符 串 ， 其 中 的 参数 timestamp 是 可 选 
的 ， 默 认 值 为 time0， 即 如 果 没 有 给 出 时 间 戳 则 使 用 本 地 当前 时 间 。 
date0 函 数 的 参数 format 的 格式 化 选项 如 表 6.1 所 示 。 


表 6.1 参数 format 的 格式 化 选项 
参数 说 了 明 
a 小 写 的 上 午 和 下 午 值 ， 返 回 值 am 或 pm 
A 大 写 的 上 午 和 下 午 值 ， 返 回 值 AM 或 PM 
B Swatch Intemet 标 准时 ， 返 回 值 000 一 999 
d 月 份 中 的 第 几 天 ， 有 前 导 零 的 2 位 数字 ， 返 回 值 01 一 31 
D 
F 


星期 中 的 第 几 天 ， 文 本 格式 ，3 个 字母 ， 返 回 值 Mon 一 Sun 
月 份 ， 完 整 的 文本 格式 ， 返 回 值 January 一 December 
小 时 ，12 小 时 格式 ， 没 有 前 导 零 ， 返 回 值 1 一 12 

G 小 时 ，24 小 时 格式 ， 没 有 前 导 零 ， 返 回 值 0 一 23 
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续 表 


中 
局 


说 了 明 


小 时 ，12 小 时 格式 ， 有 前 导 零 ， 返 回 值 01 一 12 
小 时 ，24 小 时 格式 ， 有 前 导 零 ， 返 回 值 00 一 23 
有 前 导 零 的 分 钟 数 ， 返 回 值 00 一 59 
判断 是 否 为 夏令 时 ， 返 回 值 如 果 是 夏令 时 为 1， 否 则 为 0 
月 份 中 的 第 几 天 ， 没 有 前 导 堆 ， 返 回 值 1 一 31 

星期 数 ， 完 整 的 文本 格式 ， 返 回 值 Sunday 到 Saturday 
判断 是 否 为 头 年 ， 返 回 值 如 果 是 半年 为 1， 否 则 为 0 
数字 表示 的 月 份 ， 有 前 导 零 ， 返 回 值 01 一 12 

3 个 字母 缩写 表示 的 月 份 ， 返 回 值 Jan 一 Dec 

数字 表示 的 月 份 ， 没 有 前 导 零 ， 返 回 值 1 一 12 


zl3 ll- 上 |=-|-|=|= 


n 

o 与 格林 威 治 时 间 相 差 的 小 时 数 ， 例 如 0200 

RFC 822 格式 的 日 期 例如 Thu，21 Dec 2000 16: 01: 07 +0200 

S 秒 数 ， 有 前 导 零 ， 返 回 值 00 一 59 

S 每 月 天 数 后 面 的 英文 后 级 ，2 个 字符 ， 例 如 st，nd，rd 或 者 中 。 可 以 和 j 一 起 使 用 
t 指定 月 份 所 应 有 的 天 数 

TD 本 机 所 在 的 时 区 

U 


从 UNIX 纪 元 (January 1 1970 00:00:00 GMT) 开始 至 今 的 秒 数 

星期 中 的 第 几 天 ， 数 字 表示 ， 返 回 值 为 0 一 6 
ISO-8601 格 式 年 份 中 的 第 几 周 ， 每 周 从 星期 一 开始 
4 位 数字 完整 表示 的 年 份 ， 返 回 值 如 1998、2008 

y 2 位 数字 表示 的 年 份 ， 返 回 值 如 88 或 08 

z 年 份 中 的 第 几 天 ， 返 回 值 0 一 366 
时 差 偏 移 量 的 秒 数 。UTC 西 边 的 时 区 偏 移 量 总 是 负 的 ，UTC 东边 的 时 区 偏 移 量 总 是 正 的 ， 返 回 值 
-43200 一 43200 


<|=|s 


Zz 


全 注意 : 这 里 有 效 的 时 间 蕉 典型 范围 是 格林 威 治 时 间 1901 年 12 月 13 日 20:45:54 到 2038 年 1 月 19 
日 03:14:07 ( 此 范围 符合 32 位 有 符号 整数 的 最 小 值 和 最 大 值 ) 。 在 Windows 系统 中 此 范围 
恨 制 为 从 1970 年 1 月 1 日 到 2038 年 1 月 19 日 。 


3 技巧 : 要 应 用 发 散 的 思维 方式 ， 在 考虑 编程 方法 时 就 不 能 被 date() 函 数 自身 的 功能 所 限制 ，date() 
函数 获取 的 时 间 不 只 可 以 用 来 记录 历史 中 的 菜 一 时 刻 ， 而 且 可 以 将 其 应 用 到 其 他 的 地 方 ， 
作为 一 个 有 规律 的 随机 数 。 

在 本 项 目 中 的 发 货 单 填 单 模块 中 就 是 应 用 date() 函 数 获 取 当 前 时 间 和 车 辆 ID 作为 发 货 单 的 编号 。 
关键 代码 如 下 : 


<?php 

echo date("YmdHis"); // 获 取 系 统 的 当前 时 间 
echo Sljid; // 获 取 车 辆 的 ID 

on 


“09. 
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其 运行 结果 如 图 6.28 所 示 。 
| 


车 沽 信息 查询 | evoenosossos | | sesa: E33 Fe: [ 
AiE: [| Hg 二: [ 。 司 
回执 发 货 单 确认 习 
发 货 音 查询 
客户 信息 管理 加 
车 源 信 息 管理 Sa | | 
| en | 加 


图 6.28 发 货 单 编号 生成 的 运行 结果 


技巧 : 程序 开发 不 只 是 要 看 到 其 表面 的 功能 和 属性 ， 更 重要 的 是 将 某 些 功能 或 者 属性 有 机 地 结合 
起 来 ， 从 而 开发 出 更 有 意义 的 功能 ， 这 才 是 程序 员 所 要 追求 的 。 例 如 ， 在 学 习 字符 串 中 的 
str_ireplace() 函 数 时 ， 不 但 要 知道 该 函数 的 功能 是 实现 字符 串 的 替换 功能 ， 而 且 要 学 会 如 何 
巧妙 地 运用 其 实现 更 好 的 功能 。 当 换个 角度 去 考虑 这 个 函数 的 功能 时 ， 对 这 个 函数 的 参数 
字符 串 进 行 颜色 改变 。 这 时 实现 的 功能 就 不 只 是 简单 的 字符 串 替换 ， 而 且 对 字符 串 实现 了 
描 红 的 功能 。 


6.7.3 发 货 单 填 单 的 实现 过 程 


国 发 货 单 填 单 模块 使 用 的 数据 表 : tb_customer、tb_car log、tb_shopping 

发 货 单 的 填写 是 客户 在 确定 物流 配送 路 线 以 后 填写 的 一 个 货物 配送 详细 信息 单据 ， 内 容 包 括 发 货 
单 编号 、 和 车 牌号 码 、 车 主 电话 、 发 货 人 、 发 货 人 电话 、 发 货 地 址 、 付 款 方式 、 收 货 人 、 收 货 人 电话 、 
收 货 人 地 址 和 配送 说 明 。 发 货 单 填 单 的 运行 结果 如 图 6.29 所 示 。 


发 货 单 编号 : [2007122514362913 车 短 号 码 : | 十 hres 车 主 电话 : [3604eewey 
发 全 A: | 发 货 人 电话 : [13604*er** 付款 方式 : [发 贡 人 付款 到 
[3 | 
货物 描述 : 
| 
春 市 
发 货 地 址 习 
加 
a 收 货 人 电话 : [13604#*xxss 
耳 市 
El 
有 长 春 送 到 沈阳 , 往 : 间 
说 明 : 
到 


| Es EE 


图 6.29 发 货 单 填 单 的 运行 结果 
*。310。 
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发 货 单 填 单 的 实现 通过 insert_dds.php 文 件 来 完成 ,首先 随机 生成 一 个 订单 编号 ,然后 创建 一 个 form 
表单 ， 最 后 将 表单 中 的 数据 提交 到 数据 库 中 。 在 insert_dds.php 文件 中 使 用 的 重要 表单 元 素 如 表 6.2 
所 示 。 


表 6.2 发 货 单 填 单 中 使 用 的 重要 表单 元 素 


名 称 | 元 素 类 型 重要 属性 含义 
method="post" action="insert_ dd_ok.php" onSubmit="javascript: retum wie 

forml form 表单 
check dd( 

fahuo_id text id="fahuo id" value="<?php echo date("YmdHis");?><?php echo $ljid:?>” | 发 货 单 编号 

car number text value="<?php echo $myrow[car number]?>" 车 牌号 码 

car tel text value="<?php echo $myrow[tel]:?>" 车 主 电 话 
<option selected="selected"></option><option> 发 货 人 付款 </option> 

fahuo fk select F 外 付款 方式 
<option> 第 三 方 付款 </option> 

car lo textarea Cols="65" rows="5" 说 明 

Submit submit value=" 提 交 " 提交 表单 


将 表单 中 提交 的 数据 存储 到 数据 库 是 通过 insert_dd_ok.php 文件 来 完成 的 , 在 该 文件 中 首先 连接 数 
据 库 , 然后 通过 preg_match() 函 数 判 断 表单 中 提交 的 电话 号 码 的 格式 是 否 正确 , 最 后 将 表单 中 提交 的 数 
据 存储 到 tb_shopping 表 中 ， 并 且 将 车 辆 使 用 的 说 明 提交 到 tb_car_log 表 中 ， 将 客户 信息 提交 到 
tb_customer 表 中 。 关 键 代码 如 下 : 

例 程 03 ”代码 位 置 ， 光盘 \TM\06\wlgl\insert_dd_ok.php 


<?php 

if($_SESSION[admin_user]=—true){ // 判 断 登 录 的 用 户 是 否 正 确 
include("conn/conn.php"); // 连 接 数 据 库 
S$fahuo_time=date("Y-m-d H:i:s"); // 获 取 系 统 当前 时 间 
if($Submit==true){ /如 果 提交 表单 ， 则 执行 下 面 的 语句 


让 闪 六 率 素 素 兴 当 素 素来 六 六 素来 不 不 站 检 丰 不 相关 | 里 表单 中 提交 的 电话 号 码 的 格式 是 否 正确 站 于 六 玉 六 来 六 六 六 六 六 六 六 六 六 六 率 闪 闪闪 */ 
if(preg match("/^(\d{3}-)\d{8})$I(\d{4}-)\d{7))8I^0Nd{4}-)\d{8))SI Nd{11})$/",Scar tel,Scountes){ 
if(preg match("/^(\d {3}-)\d{8»)8I(\d{4}-)0d{7D)SI^N\d{4}-)N\d{8))S Nd{11})8/", $fahuo tel,Scountes)){ 


这 preg match("/^(\d{3}-)\d{8D5I*Qd{47-)0\g77DSINg{4}-)0d{8)5 Nd{11)8/",Sshouhuo tel,$countes){ 
/和 站 直下 直 本 和 ####*# 将 表单 提交 的 数据 添加 到 jtb_shopping 表 中 下 下/ 
$query="insert into tb shopping (car number,car tel,fahuo id,fahuo user, 
fahuo tel,fahuo address,fahuo content,fahuo time,fahuo fk,shouhuo user,shouhuo address,shouhuo tel)values('$car number, 
'$car tel','$fahuo id','$fahuo user','$fahuo tel','$fahuo address','$fahuo content','$fahuo time','$fahuo fk',$shouhuo user','$sh 
ouhuo address','$shouhuo tel)"; 
$result=mysql query($query); 
/本 半 当 兴 太 六 率 当 闵 率 六 兴 六 六 闪 汪 本 本 六 兴 汪 站 不 本 本 和 告 车 辆 使 用 说 明 添 加 到 tb_car_log 表 中 于 六 六 六 六 六 来 六 率 六 六 闪闪 率 半 六 闪闪 六 站 六 率 率 率 / 
$querys="insert into 
tb car log(car log,car number,log date,fahuo id)values('$car log','$car number,'$fahuo time',$fahuo id")"; 
$results=mysql query($querys); 
/本 六 当当 六 六 六 六 六 六 当当 站 六 六 六 六 站 六 兴 相 丰 站 本 本 阁 窑 户 信息 提交 到 tb_customer 表 中 于 六 六 于 来 六 于 玉 闵 率 六 六 六 率 玉 六 率 六 来 六 六 六 六 来/ 
$queryss="insert into tb customer 
(customer_user,customer tel,customer_address)values('$fahuo_user,'$fahuo tel','$fahuo_address")"; 


1g 
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Sresultss=mysql_query($queryss); 
echo "<script>alert(' 发 货 单 添加 成 功 !");window.location.href='indexs.php?Imbs= 发 货 单 '</script>"; 
}else{ 
echo "<script>alert(' 您 输入 的 收 货 人 的 电话 号 码 格式 不 正确 !):history.backO</script>"; } 
jelsef 
echo "<script>alert(' 您 输入 的 发 货 人 的 电话 号 码 格式 不 正确 !);history.back()</script>"; } 
}else{ 
echo "<script>alert(' 您 输入 的 车 主 的 电话 号 码 格式 不 正确 !!);history.back()</script>"; } 
}7> 
<?php }else{ // 判 断 用 户 是 否 正确 登录 ， 如 果 不 是 则 返回 登录 页 面 
echo "<script>alert(' 请 您 正确 登录 !"); window.location.href="index.php';</script>";} 
> 


6.7.4 发 货 单 查询 的 实现 过 程 


国 发 货 单 查询 模块 使 用 的 数据 表 : tb_car log、tb_shopping 

发 货 单 查 询 是 为 了 便于 对 发 货 单 进行 查找 以 及 处 理 而 设计 的 一 个 功能 ， 通 过 其 可 以 准确 地 查找 到 
指定 的 发 货 单 ， 并 且 还 设置 一 个 发 货 单 删除 的 功能 ， 可 以 对 已 经 失效 或 者 作废 的 发 货 单 进行 删除 。 其 
实现 的 原理 主要 是 通过 以 发 货 单 编号 为 条 件 的 精确 查找 或 者 以 发 货 人 姓名 为 条 件 的 模糊 查询 ， 然 后 将 
查询 的 结果 输出 到 页 面 中 。 运 行 结果 如 图 6.30 所 示 。 


发 货 单 查询 : | 发 贡 单 瑟 号 避 |2007122511055215 | 提交 | 

发 货 单 编号 : |[2007122511053215 ”| 车 牌号 码 : || 于 A***** 联系 电话 : 1360434###* 
发 贷 人 : | 电话 : [EE 付款 方式 : [第 三 方 何 款 可 
货物 招 述 : | 玉米 9 

发 人 地 址 || 攻 春 市 = 

收 全 人 : ”| 以 收 货 人 电话 : 136*#### 

收 贷 地 址 : || 史 阳 = 
发 货 单 处 理 : |0 

说 明 : “| 隋 送 到 沈阳 ,往返 3 天 时 加 

说 明 :ina | 

珊 除 发 从 音 


图 6.30 ”发 货 单 查询 的 运行 结果 

发 货 单 查询 的 实现 主要 通过 hwys.php 文件 完成 , 首先 与 数据 库 建立 连接 , 然后 创建 一 个 表单 forml， 
通过 该 表单 来 提交 查询 的 条 件 ， 可 以 选择 精确 查找 〈 以 发 货 单 编 号 为 条 件 ) 或 者 模糊 查询 (以 发 货 人 
姓名 为 条 件 ) ， 最 后 根据 forml 表单 中 提交 的 数据 ， 执 行 查询 语句 ， 从 数据 库 中 读 取出 符合 条 件 的 发 
货 单 的 内 容 。 程 序 的 关键 代码 如 下 : 

例 程 04 ”代码 位 置 : 光盘 \TM\06\wlglN\hwys.php 

<?php session_start(); include("conn/conn.php"); // 初 始 化 session 变 量 ， 连 接 数 据 库 

if($_SESSION[admin_user]—true){ // 判 断 管理 员 是 否 是 正确 登录 


部 
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> 

<!--> 省 略 了 部 分 代码 <!--> 

<?php 
/二 本 本本 下 站 二 本 让 二 本 站 六 | 用 当 form1 表 单 提交 的 值 为 发 货 单 编 号 时 ， 执 行 下 面 的 语句 说 # 相 本 本 本 本 本/ 
if($select1 一 "发 货 单 编号 " and $select!=""){ 
$query="select * from tb shopping where fahuo id='$select"; 
$result=mysql_query($query); // 执 行 查询 语句 
$myrow=mysql_fetch_array( $result); 1/ 获取 查 结果 


村 水 这 六 兴 率 这 六 率 来 率 认 汪 六 水 办 果 form1 表单 提交 的 值 为 发 货 人 时 执行 下 面 的 语句 * 素来 束 束 束 束 束 事 束 束 来 来 束 来 求 束 */ 
if($select1 一 "发 货 人 " and $select!=""){ 

$query="select * from tb shopping where fahuo user='$select"™; 

$result=mysql_query( $query); // 检 索 指 定 发 货 人 的 信息 
$myrow=mysql_fetch_array( $result); 

} 


9> 
“" // 省 上 略 部 分 HTML 代 码 
<td colspan="4" bgcolor="#FFFFFF"><textarea name="car log"> 
< 输出 车 辆 日 志 中 的 车 辆 使 用 情况 -一 -一 -一 一 一 一 一 一 -一 一 一 一 -一 -一 -- 
<2php 
$querys="select * from tb_car_ log where fahuo_id=-'$myrow[fahuo id]"; /从 车 辆 日 志 表 中 查找 指定 的 数据 
$results=mysql_query($querys); // 执 行 查询 语句 
$myrows=mysql_fetch_array($results); // 获 取 查 询 结 果 
echo $myrows[car_log]; // 输 出 车 辆 日 志 信 息 
> 
</textarea></td> 
<L-- -一 -一 -一 一 -一 根据 发 货 单 的 ID 设 置 一 个 发 货 单 删除 的 超 链接 ----------------------------- - > 
<td bgcolor="#FFFFFF"><a href="fhd_qr.php?delete=<?php echo $myrow[id];?>"> 删 除 发 货 单 </a></td> 
/省 略 部 分 HTML 代 码 


<?php }else{ /判断 管理 员 是 否 正确 登录 ， 如 果 错 误 则 返回 到 登录 页 
echo "<script>alert(' 请 您 正确 登录 !"); window.location.href='index.php';</script>"; 


上 
7 


发 货 单 删除 的 操作 通过 fhd_qr.php 文件 来 完成 , 主要 根据 超 链接 中 提供 的 发 货 单 ID 执行 删除 的 操 
关键 代码 如 下 : 
例 程 05 ”代码 位 置 ， 光盘 \TM\06\wlgIMfhd_qrphp 


<?php session_start(); include("conn/conn.php"); /初始 化 session 变 量 ， 连 接 数据 库 
if($_SESSION[admin_user]—true){ 
if($delete==true) { // 判 断 提交 的 发 货 单 ID 是 否 为 真 
$query="delete from tb_shopping where id='$delete"™"; // 根 据 发 货 单 ID 执 行 删除 发 货 单 的 操作 


Sresult=mysql_query( $query); 
/于 相间 率 本 于 于 于 于 于 于 村 本 于 本 于 可 下 站 本 站 站 发 货 单 出 | 除 成功， 弹出 提示 ， 并 返回 到 上 一 页 让 闪 本 素 本 于 本 来 于 可 素来 可 来 来 来 来 束 素 来 来/ 
echo "<script>alert(' 发 货 单 删除 成 功 !);window.location.hre 全 'indexs.php?lmbs= 发 货 单 查询 ';</script>"; 
} 
jelsef 
/下 于 永 冰 宙 半 证 让 主 半 本 本 本 站 本 站 站 站 发 货 单 出 | 只 失败 ， 弹 出 提示 ， 并 返回 到 上 一- 页 过 本 李 本 本 本 本 本 本末 可 让 可可 可 本 本 可 于 本村 本 于 下 
echo "<script>alert(' 请 您 正确 登录 !); window.location.href "index.php':</script>"; 
*。313。 乡 


~-- 
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6.7.5 发 货 单打 印 的 实现 过 程 


发 货 单 的 打印 是 为 货物 的 发 送 提供 一 个 书面 的 依据 ， 作 为 企业 与 客户 商业 活动 的 凭证， 其 内 容 必 
须 真实 、 准 确 。 发 货 单打 印 的 运行 结果 如 图 6.31 所 示 。 


了 到 
党 规 | 选项 | 
广 选择 打印 机 
x 司 
急 总 
添加 打印 机 Epson 
LQ-300K 
状态 就绪 首选 项 到) 
位 置 : 
备注 : 查找 打印 机 @) 
厂 打印 到 文件 中) 
三 页 面 范围 
人 全 部 人 ) 份 数 吕 ): | 


nb re | LL 


取消 应 用 凶 


图 6.31 发 货 单打 印 的 运行 结果 
这 里 的 发 货 单打 印 技术 主要 通过 框架 打印 技术 来 完成 ， 即 只 打印 框架 中 的 内 容 ， 而 网 页 中 其 他 的 
内 容 不 打印 。 实 现 原理 是 : 首先 在 insert_dd.php 文件 中 创建 一 个 浮动 框架 ， 设 置 要 指定 打印 内 容 的 范 
围 , 并 且 连 接 到 要 打印 的 insert_dds.php 文件 , 然后 在 指定 的 文件 中 输出 要 打印 的 内 容 , 最 后 应 用 onclick 
事件 调用 parent.content,focus0 和 window.print() 方 法 实现 打印 功能 。 
在 insert_dd.php 文件 中 创建 一 个 浮动 框架 ， 设 置 框架 名 称 为 content， 设 置 打 印 的 范围 宽 97%， 高 
252%， 连 接 到 要 打印 的 insert_dds.php 文件 ， 程 序 代码 如 下 : 
例 程 06 ”代码 位 置 ， 光盘 \TM\06\wlghinsert_dd.php 
<iframe name="content" src="insert dds.php?ljid=<?php echo $ljid;?>" frameborder="0" width="97%" 
height="252%"></iframe> 
设置 要 打印 的 内 容 ， 通 过 insert_dds.php 文件 来 完成 ， 发 货 单 填写 的 内 容 以 表单 的 形式 显示 ， 其 中 
的 内 容 可 以 参考 光盘 中 TM\06\wlglinsert_dds.php 文件 ， 代 码 这 里 不 再 袭 述 。 
最 后 回 到 insert_dd.php 页 中 ,在 该 页 中 设置 一 个 超 链接 ,应 用 onClick 事件 调用 parent.content.focus() 
和 window.print( 方 法 实现 发 货 单 的 打印 功能 。 程 序 关键 代码 如 下 : 
例 程 07 ”代码 位 置 ， 光盘 \TM\06\wlglinsert_dd.php 
<a href="#" 
onClick="parent.content.focus();window.print();"> 


<img src= "images/dl 033.gif' width="87" height="27" border="0"> 
</a> 
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6.7.6 单元 测试 


在 进行 发 货 单 填 单 模块 的 测试 过 程 中 ， 当 打开 发 货 单 填 单 模块 的 页 面 时 ， 其 运行 结果 如 图 6.32 
所 示 。 


车 源 信 息 查询 
目 找 不 到 网 页 
发音 确 从 您 要 查看 的 网 页 可 能 已 被 项 除 、 各 称 已 六 更 下 ， 或 者 暂时 不 可 用 。 
发 货 单 查询 
客户 信息 管理 请 党 试 以 下 操作 
车 源 信息 管理 


。 如 果 修 已经 在 地 址 栏 中 输入 该 网 页 的 地 址 ， 请 确认 其 拼写 正确 。 
修改 罕 码 。 打开 192_ 158. 1 59 主页 , 类 后 查找 指向 你 丰 兴趣 信息 的 链接 。 


。 单 击 守 后 退 按钮 ,尝试 基地 圭 接 
. 单 击 @@ 提 到， 寻找 Internet 上 的 信息 。 


TTP 404 - 未 找到 文件 
四) Internet Explorer 


天 3| | 
图 6.32 发 货 单 填 单 模块 的 运行 结果 
在 该 页 面 中 整个 浮动 框架 中 的 内 容 没有 显示 。 分 析 错 误 原 因 ， 应 该 是 在 设置 浮动 框架 时 出 现 的 问 
题 ， 查 看 insert_dd.php 文件 中 的 代码 ， 发 现 原 来 是 设置 浮动 框架 时 指定 的 链接 文件 出 现 问 题 ， 使 用 了 
错误 的 链接 文件 名 称 。 链 接 文件 的 正确 名 称 是 insert_dds.php， 而 程序 中 将 该 文件 的 名 称 书写 为 
inser_ddes.php， 从 而 导致 页 面 中 没有 输出 任何 的 内 容 。 将 insert_dd.php 文件 中 的 内 容 进 行 修改 ， 重 新 
运行 程序 ， 运 行 结果 如 图 6.33 所 示 。 


车 源 信息 查询 发 货 单 编号 : ||2007122515225513 车 牌号 码 : | 再 A-12545 车 主 电话 : [13604338784 
发 并 人: 发 货 人 电话 : [ 付 于 方式 : 「 | 
回执 发 贫 单 确 愉 | 
发 货 单 查询 货物 搓 述 : 
客户 信息 管理 司 
车 源 信 息 管理 EE 
a 发 并 地 址 = 
中: | 可 人 电话 : 『 
收 基地 址 习 
> 习 
[WW 3 
二 说明 : 
习 
了 


6.33 ”发 货 单 模块 的 运行 结果 
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6.8 回执 单 验收 管理 模块 设计 


6.8.1 回执 单 模块 概述 


回执 单 模块 的 主要 功能 就 是 对 货物 配送 完成 确认 : 将 该 发 货 单 执行 类 型 更 新 为 “1”， 表明 该 次 物 
流 配送 已 经 完成 ; 清空 该 车 辆 的 使 用 日 志 ， 便 于 执行 下 一 个 订单 。 该 模块 的 业务 操作 流程 如 图 6.34 
所 示 。 


[9] 提交 货物 
回执 单 


车 主 


管理 


9 


图 634 回执 单 模块 的 业务 操作 流程 
6.8.2 ”回执 单 模块 技术 分 析 


在 回执 单 模块 中 ， 要 对 回执 单 进行 确认 首先 要 查找 到 指定 的 发 货 单 ， 并 且 对 其 内 容 进行 核实 。 这 
里 应 用 的 是 根据 发 货 单 的 编号 进行 查询 ， 从 数据 库 中 读 取出 符合 条 件 的 数据 。 在 执行 查询 语句 、 从 数 
据 库 中 读 取 数 据 时 ， 主 要 应 用 mysql_query0、mysqlL_num_rows0 和 mysql_fetch_array() 函 数 。 

首先 通过 mysql_query() 函 数 执行 一 个 select 查询 语句 ， 然 后 通过 mysql_num_rows0 函 数 判断 查询 
的 结果 是 否 有 值 ， 如 果 没 有 值 则 输出 “您 查找 的 发 货 单 编号 不 存在 ! ”， 如 果 有 值 则 执行 
mysql_fetch_arrau() 函 数 ， 输 出 数据 库 中 查询 到 的 数据 。 

mysql_query() 函 数 向 与 指定 的 连接 标识 符 关 联 的 服务 器 中 的 当前 活动 数据 库 发 送 一 条 MySQL 查 
询 。 语 法 如 下 : 

Tesource mysql_query ( string query [, resource link_identifier] ) 

mysql_query() 函 数 的 参数 query 是 字符 串 的 类 型 ， 传 入 的 是 SQL 指令 ; 参数 link_identfier 是 资源 
类 型 ， 传 入 的 是 由 mysql_connect() 函 数 或 者 mysql_pconnectO) 函 数 返回 的 连接 号 。 如 果 省 略 该 参数 ， 则 
会 使 用 最 后 一 个 打开 的 MySQL 数据 库 连接 。 


全 注意 : 查询 字符 囊 不 应 以 分 号 结束 。 
mysql_num_rows() 函 数 获取 结果 集中 行 的 数目 。 语 法 如 下 : 


int mysql_num_rows ( resource result ) 
*316。 
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全 注意 : 该 函数 仅 对 SELECT 语句 有 效 。 
mysql_fetch_array0 函 数 返 回 根据 从 结果 集 获取 的 行 生成 的 数组 ， 如 果 没 有 更 多 行 则 返回 false。 语 
法 如 下 : 
array mysql_fetch_array ( resource result [, int result_type] ) 
mysql_fetch_array0 函 数 的 参数 说 明 如 表 6.3 所 示 。 
表 6.3 mysql_fetch_array() 函 数 的 参数 说 明 


参数 名 称 说 了 明 
result 资源 类 型 的 参数 ， 要 传 入 的 是 由 mysql_query0 函 数 返 回 的 “数据 指针 ” 
可 选项 ,整数 型 参数 ,要 传 入 的 是 MYSQL_ASSOC、MYSQL_NUM 和 MYSQL_BOTH 3 种 由 PHP 定 义 
好 的 常数 之 一 ， 默 认 值 是 MYSQL_BOTH 
用 MYSQL_ASSOC 只 得 到 关联 索引 (相当 于 mysql_fetch_assoc0) 函 数 ) 
用 MYSQL_NUM 只 得 到 数字 索引 (相当 于 mysql_fetch_row() 函 数 ) 
用 MYSQL_BOTH 将 得 到 一 个 同时 包含 关联 和 数字 索引 的 数组 


result_type 


全 注意 : 本 函数 返回 的 字段 名 是 区 分 大 小 写 的 。 
通过 上 述 3 个 函数 就 可 以 完成 从 数据 库 中 读 取 数据 ， 并 且 将 数据 输出 到 页 面 的 功能 。 
公 注意 : 使 用 该 种 方法 输出 的 只 是 数据 库 中 的 一 条 数据 .如果 加 上 while 循环 语句 ， 那 么 就 可 以 完成 
数据 库 中 所 有 符合 条 件数 据 的 循环 输出 。 


应 用 while 循环 语句 读 取 数 据 库 中 的 数据 ， 这 里 以 读 取 tb_shopping 表 中 的 数据 为 例 ， 程 序 代 码 
如 下 : 


<?php include("conn/conn.php"); // 连 接 数 据 库 
$query="select * from tb_shopping "; // 编 写 查询 语句 
$result=mysql_query( $query); // 执 行 查询 语句 

oo if(mysql_num_rows($result)<1){ // 判 断 数据 库 中 是 否 存在 数据 
echo "您 查找 的 内 容 不 存在 1"; 
Yelsef 
© while($myrow=mysql_fetch_array(S$result){ // 循 环 输出 数据 库 中 的 数据 
> 
<?php 
echo $myrow[id]; /| 输出 数据 库 中 数据 

x 

人 // 输 出 内 容 的 代码 部 分 略 

<Iphp }?> 

< 代码 贴 十 


@ mysql num rows(): 返回 根据 从 结果 集 获 取 的 行 生 成 的 数组 ， 如 果 没 有 更 多 行 则 返回 false。 
@ mysql_fetch_array(): 获取 结果 集中 行 的 数目 。 该 函数 只 对 select 语句 有 效 。 
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6.8.3 回执 单 验收 模块 的 实现 过 程 


国 。 回执 单 验 模块 使 用 的 数据 表 : tb_car log、tb shopping 
回执 单 验收 模块 的 主要 功能 就 是 对 货物 配送 完成 确认 ， 运 行 结果 如 图 6.35 所 示 。 
车 庆 信 息 查询 [am E00T122511053215 EJ 


发 货 单 信号 :|2007122511053215 车 牌号 码 : 器 eres 联系 电话 : |136043ywwyy 
发 商人 : |[13604338764 电话 : [Sm 付款 方式 : [第 三 方 他 各 本 


Cr | 


图 635 回执 单 验收 模块 的 运行 结果 
回执 单 验收 模块 的 实现 过 程 是 ， 首先 在 select_dhd.php 页 中 根据 发 货 单 的 编号 查询 出 指定 的 发 货 
单 ， 对 发 货 单 进行 核实 ， 然 后 单 击 “ 发 货 订 单 确认 ” 超 链 接 ， 实 现 回执 单 的 验收 。 关 键 代码 如 下 ; 
例 程 08 ”代码 位 置 ， 光盘 \TM\06\wlglselect_dhd.php 


<?php 
include("conn/conn.php"); // 连 接 数 据 库 
if($Submit==true){ 
$query="select * from tb_shopping where fahuo_id='$select"™; // 编 写 查询 语句 
$result=mysql_query($query); // 执 行 查询 语句 
ifmysql_num_rows($resulb<1){ // 判 断 数据 库 中 是 否 存在 数据 
echo "您 查找 的 发 货 单 编号 不 存在 1"; 
jelsef 
$myrow=mysql_fetch_array($result); /输出 数据 库 中 的 数据 
> 


// 输 出 内 容 的 代码 部 分 略 
<td colspan="4" bgcolor="#FFFFFF"> 
<textarea name="car log"> 
<?php 
/于 站 本 站 站 本 站 本 本 站 本 站 站 本 站 在 相 据 提交 的 货物 编号 ， 查 询 车 辆 日 志 中 的 对 应 日 志 闻 本 站 本 本 本 本 本 本 本 本 本 间 本 本/ 
$querys="select * from tb car log where fahuo id='S$myrow[fahuo id]"; 


Sresults=mysql_query($querys); // 执 行 查询 语句 
$myrows=mysql_fetch_array($results); // 输 出 数据 库 中 的 数据 
echo $myrows[car_log]; // 输 出 数据 库 中 的 数据 
> 
</textarea></td> 
// 输 出 内 容 的 代码 部 分 咯 
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< 一 一 一- 设置 超 链接 ， 执 行 发 货 单 的 确认 一 -一 一 一 一 一 一 一 一 -一 一- 一 一 -一 - > 
<td bgcolor="#FFFFFF"><a href="fhd_qr.php?fahuo_id=<?php echo $myrow[fahuo_id];?>"> 发 货 订单 回 执 确认 
</a></td> 
最 后 在 fhd_qr.php 页 根据 超 链接 提供 的 发 货 单 编号 更 新 发 货 单 类 型 为 “1”， 清空 对 应 车 辆 的 使 用 
日 志 。 其 程序 的 关键 代码 如 下 : 
例 程 09 ”代码 位 置 ， 光盘 \TM\06\wlgl\Mfhd_qrphp 


<?php session_start(); include("conn/conn.php"); /初始 化 session 变 量 
if($_SESSION[admin_user]—true){ /1/ 判 断 用 户 是 否 是 正确 登录 
if($_GET[fahuo id]==true){ // 判 断 超 链 接 传递 的 变量 值 是 否 为 真 


让 不 术 玉 来 本 本 术 术 本 本本 超 链 接 传递 的 变量 值 为 条 件 ， 编写 删除 语 多 站 让 中 中 中 下 机 本 疝 相 本 来 本 束 束 可 来 来 可 */ 
$query="delete from tb car log where fahuo id='$fahuo id"; 
$result=mysql_query( $query); // 执 行 删除 语句 
人 本 本 本 术 太 本 本 本 本 本 术 本 本 本 本 本 本 本 本 本 本 亲 [发 货 单 数据 表 中 发 货 的 类 型 为 “ 出 罗素 率 素 率 闵 玉 六 六 六 六 六 六 素 闵 素 闵 闵 闵 冰冰 六 六 六 */ 
$query="update tb shopping set fahuo ys=1' where fahuo id='$fahuo id' "; 
$result=mysql_query( $query); 
echo "<script>alert(' 发 货 回 执 单 处 理 成 功 !");window.location.href='indexs.php?imbs= 回 执 发 货 单 确认 
“</script>"; } 
jelsef 
echo "<script>alert(' 请 您 正确 登录 !"); window.location.href="index.php';</script>"; 


上 
> 


6.9 ”基础 信息 管理 模块 设计 


6.9.1 基础 信息 管理 模块 概述 


基础 信息 管理 模块 主要 包括 客户 信息 管理 ， 用 于 添加 客户 信息 和 删除 客户 信息 ;车 源 信息 管理 ， 
主要 用 于 对 车 源 信息 进行 管理 ， 实 现 车 源 信息 的 添加 、 修 改 和 删除 功能 ;管理 员 信 息 管理 ， 用 于 修改 
管理 员 的 密码 。 基 础 信息 管理 模块 的 功能 结果 如 图 6.36 所 示 。 


ga 
~ CM 


全 修改 密码 


图 6.36 ”基础 信息 管理 模块 的 功能 结构 图 


PHP 项 目 开发 全 程 实录 


6.9.2 ”基础 信息 管理 模块 技术 分 析 


修改 管理 员 密 码 的 模块 中 ， 在 对 密码 进行 处 理 的 过 程 中 用 的 是 面向 对 象 技 术 实现 密码 的 修改 。 
面向 对 象 技术 的 关键 就 是 类 的 创建 ， 首 先 创 建 一 个 chkuser 类 ， 其 中 定义 5 个 数据 成 员 ， 实 现 对 管 
理 员 密码 的 修改 ， 分 别 是 管理 员 名称 ($admin_user) 、 管 理 员 密码 ($admin_pass) 、 管 理 员 新 密码 
($admin_new_pass) 、 管 理 员 新 密码 确认 ($admin_new_pass2) 和 验证 码 ($yzm) ， 然 后 应 用 chkuser 
函数 实现 数据 成 员 的 初始 化 ， 最 后 应 用 数据 成 员 函 数 chkinput 实现 密码 的 修改 。 程 序 代码 如 下 : 
例 程 10 ”代码 位 置 ; 光盘 \TM\06\wlgl\update_pass_ok.php 


<?php 。 session_start(); /初始 化 session 变 量 

class chkuser{ /创建 一 个 chkuser 类 
var $admin_user; /创建 数据 成 员 ， 用 户 名 
var $admin_pass; /创建 数据 成 员 ， 密 码 
var $admin_new_pass; /创建 数据 成 员 ， 新 密码 
var $admin_new_pass2; /创建 数据 成 员 ， 密 码 确认 
Var $yzm; /创建 数据 成 员 ， 验 证 码 

function chkuser($x,$y, Sm,$n,$z){ // 创 建 chkuser 函 数 ， 实 现 数据 成 员 初 始 化 


S$this->admin_user=$x; 
S$this->admin_pass=S$y; 
S$this->admin_new_pass=$m; 
S$this->admin_new_pass2=$n; 
S$this->yzm=$z; 
} 
© function chkinputO{ // 创 建 chkinput 函 数 实现 密码 更 改 
// 浏 断 输入 的 验证 码 是 否 正确 
© if(strval($this->yzm)!=$_SESSION["autonum1"]){ 
echo "<script>alert(' 验 证 码 输入 错误 1");history.back();</script>"; 
exit; 
) 
include("conn/conn.php"); // 连 接 数 据 库 
// 判 断 输入 的 密码 是 否 正确 
$query=mysql_query("select * from tb_admin where admin_user="".$this->admin_user." and 
admin_pass=".$this->admin_pass."™"); 
if(mysql_num _rows($query)<1){ 
/和 半音 由 中间 于 由 半球 则 灶 站 站 站 站 站 下 本 站 共 ] 时 密码 不 正确 风 | 提 示 重 新 输 入 密 夺 本 本 于 宙 站 再 相 员 于 下来 于 中叶 于 虽 水 
echo "<script>alert(' 您 输入 的 密码 不 正确 ， 请 重新 输入 ');history.back();</script>"; 
else 
E 于 太太 来 玉 本 太太 本 本 本 本 本 本 不 检 本 本 加 果 密 * 码 正确 ， 则 应 用 更 新 语句 ， 实 现 密码 的 更 改 直 下 来 玉 来 来 率 素来 率 率 / 
$queryl=mysql_query("update tb_admin set admin pass=".$this->admin_new_pass.™"); 
if($query 1=—true){ 
echo "<script>alert(' 密 码 更 改 成 功 ");history.back();</script>"; 
} 


} 


Dit SA -全 | 人 上 Qs ii 宁 


Sa 


第 6 章 物流 配送 信息 网 (Apache+PHP+phpMyAdmin+MySQL 5.0 实现 ) 


@ $chk=new 
chkuser($_POST[admin_user],md5($ POST[admin pass]),md5($_POST[admin new_pass]),$ POST[admin new_pass2],$ P 
OST[yzm]); 
$chk->chkinput(); 
?> 


< 代码 贴 十 
@ chkuser: 创建 一 个 类 名 称 为 chkuser， 用 于 修改 管理 员 密 码 。 
四 chkinput (): 创建 一 个 自 定义 函数 chkinput()， 用 于 实现 密码 修改 。 
上 @ strval (0): 获取 变量 的 字符 囊 。 
@ new chkuser: 实现 类 的 实例 化 ， 应 用 类 实现 密码 修改 。 


6.9.3 客户 信息 管理 的 实现 过 程 
国 客户 信息 管理 模块 使 用 的 数据 表 : tb_customer 


客户 信息 管理 模块 的 主要 功能 就 是 向 数据 库 中 添加 客户 信息 ， 并 且 可 以 对 指定 的 客户 进行 删除 操 
作 。 客 户 信息 管理 模块 的 的 运行 结果 如 图 6.37 所 示 。 


车 源 信息 查询 客户 信息 管理 
发 货 单 客户 姓 各 : 三 ** 
电话 : 1360433##*#* 
联系 地 址 。 | 从 春 市 = 
有 | 
客户 姓名 电话 联系 地 址 操作 
Bu 0431-12345678 长 春 市 删除 
下 李 *# 13604338784 四 平市 山 除 


图 6.37 客户 信息 管理 模块 的 运行 结果 


客户 信息 管理 模块 主要 通过 customer.php、customer_ok.php 和 delete_customer.php 文件 来 完成 。 首 
先 通过 customer.php 文件 来 添加 客户 信息 ， 并 且 输 出 数据 库 中 的 所 有 客户 信息 ， 设 置 删除 客户 信息 的 
超 链接 。 其 输出 客户 详细 信息 的 关键 代码 如 下 : 

例 程 11 ”代码 位 置 : 光盘 \TM\06\wlgl\customer.php 


<?php include("conn/conn.php");: // 连 接 数 据 库 
$query=mysql_query("select * from tb_customer "); // 执 行 查询 语句 ， 从 数据 库 中 读 取 数据 
while($myrow=mysql_fetch_array($query))f // 通 过 while 循 环 语句 ， 循 环 输出 数据 库 中 的 数据 
<t> 


<td height="26" align="center" bgcolor="#FFFFFF"><?php echo $myrow[customer_user];?></td> 
321 乡 
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<td align="center" bgcolor="#FFFFFF"><?php echo $myrow[customer tel]:?></td> 
<td align="center" bgcolor="#FFFFFF"><?php echo $myrow[customer_address]:?></td> 
!-- 一 -设置 删除 客户 信息 的 超 链接 ， 并 且 设置 客户 的 ID 为 变量 --- 
<td align="center" bgcolor= "三 FFFFF"><a hre 合 "delete_customer.php?delete=<2php echo 
$myrow[customer id];?>"> 删 除 </a></td> 
</t> 
<?php }7> 


客户 信息 添加 的 操作 通过 customer_ok.php 文件 完成 ， 首 先 连接 数据 库 ， 然 后 判断 提交 的 电话 号 码 
格式 是 否 正确 ， 最 后 将 客户 信息 数据 提交 到 数据 库 中 。 程 序 的 代码 如 下 : 
例 程 12 ”代码 位 置 ， 光盘 \TM\06\wlgl\customer_ok.php 
<?php include("conn/conn.php"); // 连 接 数 据 库 
if($Submit==true and $customer_user—true){ // 判 断 提交 的 值 是 否 为 真 
大 村 计 于 可 束 训 训 可 机 市 刺 训 可 训 机 本 可 训 训 可可 本 本 可 本 可 洁 | 潮 [ 提 交 的 ] 电话 号 码 格式 是 否 正 确 六 本 村 机 机 机 可 机 机 机 可 可 束 机 训 刺 束 束 束 可 束 束 束 训 来 素 */ 


if(preg_match("/^(\d {3}-)(\d{8))sI Nd{4}-)\d{7))8I^0\qd{4}-)(\d{8})5/QNd{11))$/",S$customer_tel,$countes)){ 
/相让 于 于 于 下 于 下 证 本 于 上 直下 本 本寺 让 丰 站 间 提交 了 的] 数据 添加 到 | 客户 信息 表 中 于 于 六 于 六 六 来 六 玉 于 水 六 / 


$query=mysql query("insert into 
tb customer(customer user,customer tel,customer address)values('$customer user','$customer tel','$customer address')"); 
if($query—true)!{ // 如 果 添 加 操作 成 功 ， 弹 出 提示 ， 并 返回 首页 
echo "<script> alert(' 客 户 信息 添加 成 功 ');window.location.href="indexs.php?lImbs= 客 户 信 息 管理 
"scrip>"; 
} 
yelse{ // 如 果 添 加 操作 失败 ， 弹 出 提示 ， 并 返回 上 一 页 
echo "<script>alert(' 您 输入 的 电话 号 码 格式 不 正确 !!");history.back()</script>"; 
} 
} 
> 


客户 信息 删除 的 操作 通过 delete_customer.php 文件 来 完成 ， 主 要 以 超 链 接 中 提交 的 变量 为 根据 ， 删 
除数 据 库 中 指定 的 客户 信息 。 程 序 的 关键 代码 如 下 : 
例 程 13 ”代码 位 置 : 光盘 \TM\06\wlgl\delete_customer.php 
<?php include("conn/conn.php"); /| 连接 数据 库 
if($delete==true){ // 判 断 提交 的 变量 值 是 否 为 真 
/下 半球 根据 $5 GET 获 取 的 变量 值 为 依据 ， 执 行 删除 语义 
$query=mysql query("delete from tb customer where customer id='$ GET[delete]"); 
if($query){ // 如 果 删 除 操作 成 功 ， 则 弹出 提示 ， 并 返回 首页 
echo "<script> alert(' 客 户 信息 添 加 成 功 ");window.location.href=indexs.php?lImbs= 客 户 信息 管 理 
“</script>"; 


} 
2 


6.9.4 车 源 信息 管理 的 实现 过 程 


国 ”车 源 信息 管理 模块 使 用 的 数据 表 : tb_car 
车 源 信息 管理 模块 主要 实现 对 车 辆 信息 的 添加 、 修 改 和 删除 操作 。 车 源 信息 管理 模块 的 运行 结果 
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如 图 6.38 所 示 。 
车 源 信息 查询 
发 贷 间 夺 源 信息 管理 | 寺 4-78745 | 撞 交 | 
回执 发 货 单 确认 二 一 _ 
RS #S: | Fs: | 
客户 信息 管理 身份 证: 56055565 ee E 
ER 车 辆 描述 : 
= 电话 : EE 
修改 密码 剧 
奏 - 沉 耳 - 天 走 E 
pl 地 址 : | 长春 市 = 运 罗 路 线 : 
加) 
日) 本 - 硬 己 了 
[一 | 
图 6.38 车 源 信息 管理 模块 的 运行 结果 
车 源 信 息 管 理 模块 主要 由 两 个 文件 组 成 。 一 个 是 car.php 文件 ， 以 表单 文件 为 主 用 于 输出 车 辆 的 信 


息 和 提交 车 辆 的 信息 。 设 置 form2 表单 ， 根 据 车 牌号 码 从 数据 库 中 读 取 对 应 车 辆 的 信息 ， 进 而 实现 对 


车 辆 信息 到 数据 库 。fbrml 表单 中 使 用 的 重要 元 素 如 表 6.4 所 示 。 


名 称 


forml 


元 素 类 型 


form 


表 6.4 车 源 信息 管理 模块 中 使 用 的 重要 表单 元 素 
重要 属性 


method="post" action="car_insert_ok.php” 


的 修改 或 者 删除 操作 ; 设置 forml 表单 ， 用 于 显示 从 数据 库 中 读 取 的 车 辆 信息 和 直接 添加 


表单 


onSubmit="javascript:return check_car(forml):” 


usemame 


text 


id="usemame" value="<?php echo $myrows[usemame]:?>" 


车 主 姓名 


car_ number text id="car_number" value="<?php echo $myrows[car_ number]:?>" 车 牌号 码 
car tel text value="<?php echo $myrow[tel];?>" 车 主 电话 
user number text id="user_number" value="<?php echo $myrows[user_number]:?>" 身份 证 号 码 
car content textarea <2php echo Smyrows[car content]:?> 车 辆 描述 
address, textarea ?php echo Smyrows[address];?> 家 庭 地 址 
car road textarea <2php echo Smyrows[car road];?> 运输 路 线 
Submit submit value=" 提 交 " 提交 表单 
Submit2 submit value=" 修 改 " 提交 表单 
Submit4 submit value=" 删 除 " 提交 表单 


另 一 个 是 car_insert_ok.php 文件 , 通过 该 文件 实现 对 表单 中 提交 的 数据 进行 处 理 。 首 先 连接 数据 库 ， 
提交 的 值 进行 判断 ， 当 按钮 SSubmit 的 值 为 “提交 ”时 ， 将 提交 的 数据 存储 到 指定 的 数 
据 表 中 ;， 当 按钮 SSubmit2 的 值 为 “修改 ”时 ， 则 更 新 语句 ， 对 车 辆 的 信息 进行 更 新 ， 当 按钮 SSubmit4 
的 值 为 “删除 ”时 ， 则 执行 删除 语句 ， 将 指定 的 车 辆 信息 删除 。 程 序 关键 代码 如 下 : 


然后 根据 表单 中 


0. 
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例 程 14 ”代码 位 置 ， 光盘 \TM\06\wlgl\car_insert_ok.php 


<?php session_start(); include("conn/conn.php"); // 初 始 化 session 变 量 ， 连 接 数 据 库 
oo if($_SESSION[admin_user]—true){ // 判 断 管理 员 是 否 是 正常 登录 
if($Submit==" 提 交 "){ // 判 断 表单 提交 的 值 是 否 为 "提交 " 
Vd 本 本 本 本 本本 本 本 本 本 本 本 本 本 本 本 本 本 本 本 关于 表单 中 提交 的 电话 号 码 的 格式 是 否 正 确 *** 六 六 来 玉 六 永 来 六 六 来 六 来 */ 
@ ipreg_ match("\d{17}Nd|XINd{15}/",$user number,$counts)){ 


这 preg match("/^(\d{3}-)N\d{8)5/Qd{4}-)(\d{7DSI"0Nd{4}-)N\d{87)$ Nd{11))$/",Suser tel,Scountes)){ 
/本 本 让 让 可 可 可 机 可 可 训 本 可 训 本 事 让 本 宙 本 调调 机 机 呈 本 半生 表单 中 的 数据 添加 到 tb car 数 据 表 中 检 相 机 本 机 可 可 事 可 可 事 可 束 冰 可 冰 事 束 事 冰 */ 
$query=mysql_query("insert into 
tb car(username,user number,tel,address,car number,car road,car content)values('$username','$user number',$user tel',$addr 
ess','$car_number','$car_road','$car_content")"); 
if($query—true){ 
echo "<script>alert(' 车 源 信息 添加 成 功 !");window.location.href='indexs.php?lmbs= 车 源 信息 管 
理 ';</script>"; } 
Yelse{ 
echo "<script>alert(' 您 输入 的 电话 号 码 格式 不 正确 !):history.backO</script>";， } 
Jelse{ 
echo "<script>alert(' 您 输入 的 身份 证 号 码 的 格式 不 正确 !!);history.backQO<scrip>";  } 


灰 当 兴 率 认 认 究 率 六 率 兴 闪闪 六 太 率 六 率 站 不 率 兴 闪 站 站 相 着 | 肝 -表单 提交 的 值 是 否 为 " 修 玫 "* 衬 于 六 玉 来 玉 来 来 素 六 六 六 来 六 六 冰 闵 闪闪 六 束 闪 水 闪闪 */ 

© itSSubmit2 一 "修改 "){ 

人 灰 率 率 率 率 兴 这 率 半 素 案 率 来 丰 太 检 站 不 相 村 相 丰 关 | 肝 [电话 号 码 的 格式 是 否 堪 确 叶 本 中 本 机 员 中 来 来 可 可 可 来 来 素 束 束 束 来 束 束 束 束 于 束 束 玉 */ 

这 preg match("\d{17}NdIXINd{15}/",$user number,$counts)){ 

if(preg_mateh("/*(\d {3}-)\d{8)8/0d{4})0d{7))8/ Od{4}-)0\d{8))S Od{11})8/",Suser_tel,Scountes){ 

人 中 中 直 让 中 中 由 中 让 让 中 机 让 让 相让 本 相让 本 让 让 中 主语 下 亲人 bar 郑 据 表 中 的 北 据 机 中 让 让 机 让 机 机 让 机 让 机 机 机 让 机 相机 相机 机 本 本 机 */ 

$query="update tb_car set username='Susername', user_number='$user_number', tel='$user_tel', 
address='$address', car number='$car number, car road='$car road', car content='$car content'"; 

$result=mysql_query( $query); 

if($result==true){ 
echo "<script>alert( 车 源 数据 更 新 成 功 !);window.location.href-'indexs.php?lmbs= 车 源 信息 管 


理 ';</script>";} 
}elsef 
echo "<script>alert(' 您 输入 的 电话 号 码 格式 不 正确 !1");history.back()</script>";} 
jelsef 
echo "<script>alert(' 您 输入 的 身份 证 号 码 的 格式 不 正确 !!");history.back 〇 </script>"; } 
» 闪闪 夺标 本 站 相关 | 于 下 单 提交 的 ] 值 是 否 为 " 诅 | 除 "下 玉 于 六 玉 这 冰 闪 这 半 半球 冰 于 素 站/ 
@ 这 SSubmit4 一 "删除 "){ 
$query="delete from tb_car where car_number='$car_number"™; // 删 除 tb_car 数 据 表 中 的 数据 
Sresult=mysql query($query); 
if($result==true){ 
echo "<script>alert(' 车 源 数据 删除 成 功 !");window.location.href='indexs.php?imbs= 车 源 信息 管 
理 ';</script>"; 
上 
> 


<2php Yelse{ 
echo "<script>alert(' 请 您 正确 登录 !"); window.location.hre 人 ="index.php';</script>"; 


bE 
?> 
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Ah 代码 贴 二 

@S SESSION[admin_user]: 判断 用 户 是 否 是 正常 登录 。 

@ preg_match(): 应 用 preg_match 验证 电话 号 码 的 格式 是 否 正确 。preg_match() 对 正则 表达 式 进 行 匹配 。 返 回 匹配 
的 次 数 ，0 次 (没有 匹配 ) 或 者 1 次 ， 因 为 preg_match() 函 数 在 第 一 次 匹配 之 后 将 停止 搜索 ， 出 错 返回 false。 

目 $Submit2 一 "修改 ": 判断 表单 提交 的 值 是 否 等 于 修改 ， 如 果 等 于 修改 则 执行 修改 的 操作 。 

@ $Submit4==" 删 除 ": 判断 表单 提交 的 值 是 否 等 于 删除 ， 如 果 等 于 删除 则 执行 删除 语句 。 


6.10 ”开发 技巧 与 难点 分 析 


6.10.1 应 用 存储 过 程 实现 管理 员 登 录 


在 物流 配送 信息 网 系统 中 ， 管 理 员 登 录 是 通过 存储 过 程 来 实现 的 。 下 面 就 来 讲解 一 下 如 何 创 建 存 
储 过 程 和 应 用 存储 过 程 。 

MySQL 5.0 以 后 的 版 本 中 开始 支持 存储 过 程 ， 存 储 过 程 具 有 一 致 性 、 高 效 性 、 安 全 性 和 体系 结构 
等 特点 ， 其 将 在 以 后 的 项 目 中 得 到 广泛 的 应 用 。 

一 个 完整 的 存储 过 程 包括 名 称 、 参 数列 表 ， 以 及 很 多 SQL 语句 集 。 下 面 以 一 个 存储 过 程 的 定义 过 
程 为 例 ， 对 其 结构 进行 详细 的 讲解 。 
@ cereateprocedure procedure name (in parameter integer) 
四 begin 

declare variable varchar(20); 

if parameter=1 then 

set variable='Apache’; 

else 

set variable=MySQL'; 

end if; 

insert into tb_table (tb_name) values (variable); 

end; 


Ah 代码 贴 二 
@ create procedure: 创建 存储 过 程 ， 以 关键 字 create procedure 开始 ， 后 面 紧 跟 存储 过 程 的 名 称 和 参数 。 
@ begin: MySQL 存储 过 程 的 语句 块 以 begin 开始 。 
@ end: MySQL 存储 过 程 以 end 结束 。 


MySQL 中 存储 过 程 的 建立 以 关键 字 create procedure 开始 ， 后 面 紧 跟 存 储 过 程 的 名 称 和 参数 。 
MySQL 的 存储 过 程 名 称 不 区 分 大 小 写 ， 例 如 PROCEDURESO 和 procedures() 代 表 同 一 存储 过 程 名 。 存 
储 过 程 名 不 能 与 MySQL 数据 库 中 的 内 建 函数 重 名 。 

存储 过 程 的 参数 一 般 由 3 部 分 组 成 。 第 一 部 分 可 以 是 in、out 或 inout。in 表示 向 存储 过 程 中 传 入 
参数 ，out 表示 向 外 传 出 参数 ， inout 表示 定义 的 参数 可 传 入 存储 过 程 并 可 以 被 存储 过 程 修改 后 传 出 存 
储 过 程 ， 存 储 过 程 默 认为 传 入 参数 ， 所 以 参数 in 可 以 省 略 。 第 二 部 分 为 参数 名 。 第 三 个 部 分 为 参数 的 类 


4 


PHP 项 目 开 发 全 程 实录 


型 ， 该 类 型 为 MySQL 数据 库 中 所 有 可 用 的 字段 类 型 ， 如 果 有 多 个 参数 ， 参 数 之 间 可 以 用 逗号 进行 分 割 。 
MySQL 存储 过 程 的 语句 块 以 begin 开始 ， 以 end 结束 。 语 句 体 中 可 以 包含 变量 的 声明 、 控 制 语 句 、 

SQL 查询 语句 等 。 由 于 存储 过 程 内 部 语句 要 以 分 号 结束 ， 所 以 在 定义 存储 过 程 前 应 将 语句 结束 标志 “;” 

更 该 为 其 他 字符 , 并 且 该 字符 在 存储 过 程 中 出 现 的 几率 也 应 该 较 低 ， 可 以 用 关键 字 delimiter 更 改 , 例如 : 


mysql>delimiter // 


全 注意 : 在 应 用 delimiter 关键 字 更 改 存储 过 程 中 的 语 各 结束 标志 “:" 时 ,所 使 用 的 字符 必须 与 delimiter 
关键 字 之 间 保 留 一 个 空格 ， 否 则 该 存储 过 程 将 会 出 现 错误 ， 不 能 成 功 创建 。 

存储 过 程 创建 之 后 ， 可 用 如 下 语句 进行 删除 ， 参 数 procedure_name 指 存 储 过 程 名 。 

drop procedure procedure_name 

MySQL 存储 过 程 是 在 命令 提示 符 下 创建 的 ， 其 操作 步骤 如 下 : 

(1) 打开 “命令 提示 符 ” 

(2) 进入 “命令 提示 符 

mysql -u 用 户 名 -p 用 户 密码 


(3) 更 改 语句 结束 符号 ， 将 语句 结束 符 更 改 为 “//”， 代 码 如 下 : 


后 ， 首 先 登录 MySQL 数据 库 服务 器 ， 在 命令 提示 符 下 输入 如 下 命令 : 


delimiter // 
(4) 创建 存储 过 程 前 应 首先 选择 某 个 数据 库 ， 代 码 如 下 : 
use 数据 库 名 


(5) 创建 存储 过 程 。 

(6) 通过 call 语句 调用 存储 过 程 

下 面 以 本 项 目 中 的 管理 员 登 录 模块 为 例 ， 对 存储 过 程 进行 实例 化 的 讲解 。 首 先 创建 存储 过 程 ， 在 
命令 提示 符 中 输入 代码 ， 如 图 6.39 所 示 。 


| 口 | x| 


-comnunity-nt—log 


”or ’\h’ for help. Type ’\c’ to clear the buffer. 


db_wlgl 
| 


e procedure adnin_re n x varcharC50),in y varchar(50)> 


t * from th_adnin where adnin_user=x and adnin_pas 


图 6.39 创建 存储 过 程 


SS 
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然后 在 index.php 文件 中 编写 PHP 脚本 语句 ， 调 用 存储 过 程 实现 用 户 登录 。 关 键 代 码 如 下 : 
例 程 15 ”代码 位 置 ， 光盘 \TM\06\wlgl\index.php 


<?php 
if($_POST[admin_user]!="" || $_POST[admin_pass]!=""){ // 获 取 表 单 提交 的 数据 
Sconn=new mysqli("localhost","root", "root","db_wlgl"); // 连 接 数 据 库 
S$conn->query("set names gb2312"); // 指 定 字符 编码 格式 
Sadmin_user=$_POST[admin_user]; // 获 取 变 量 值 
S$admin_pass=md5($_POST[admin_pass]); // 获 取 变 量 值 
$sql=$conn->query("call admin_reg(".$admin_user.",".$admin_pass.")"); /调用 存储 过 程 
S$res=$sql->fetch_array(MYSQL_BOTH); /输出 结果 
if($res!=NULL){ 
session_register("admin_user"); // 定 义 session 变 量 
session_register("admin pass"); 
echo "<script>alert(' 用 户 注册 成 功 !");window .location.href='indexs.php';</script>"; 
}else{ 
echo "<script>alert(' 用 户 注 册 失 败 "");</script>"; 
} 
} 
es 


6.10.2 应 用 正则 表达 式 验证 电话 号 码 


在 物流 配送 信息 网 中 ， 确 认输 入 的 电话 号 码 正确 与 否 是 一 个 非常 重要 的 问题 ， 如 果 客 户 在 填写 订 
单 时 使 用 了 错误 的 电话 号 码 ， 那 么 就 会 带 来 很 多 不 必要 的 麻烦 ， 所 以 在 填写 电话 号 码 时 一 定 要 注意 电 
话 号 码 的 准确 性 。 为 了 更 好 地 确保 电话 号 码 输入 的 准确 性 ， 可 以 通过 程序 对 其 进行 控制 。 虽 然 程 序 不 
能 判断 电话 号 码 输入 得 是 否 正 确 ， 但 是 通过 程序 可 以 对 电话 号 码 的 格式 进行 判断 ， 从 而 避免 一 些 电 话 
号 码 在 录入 的 过 程 中 出 现 多 写 或 者 漏 写 数 字 的 错误 。 

验证 电话 号 码 格式 是 否 正确 可 以 通过 正则 表达 式 来 完成 。 通 过 正则 表达 式 可 以 有 效 地 判断 输入 电 
话 号 码 的 格式 是 否 正确 。 

在 进行 判断 之 前 首先 要 对 电话 号 码 的 格式 进行 分 类 : 第 一 类 区 号 是 3 位 数字 ， 其 他 是 8 位 数字 ; 
第 2 类 区 号 是 4 位 数字 ， 其 他 是 7 位 数字 ; 第 3 类 区 号 是 4 位 数字 ， 其 他 是 8 位 数字 ; 第 4 类 是 手机 
电话 号 码 ， 由 11 位 数字 组 成 。 

然后 编写 一 个 判断 电话 号 码 格式 的 正则 表达 式 ， 其 代码 如 下 : 

Ad3HDCdt8DSAGd4)Od7DSAOd4-)Cdt8DSIAOd1IDS/ 

正则 表达 式 的 功能 分 析 如 下 : 使 用 “^” 和 “$” 对 字符 串 进行 边界 限制 ， 对 区 号 从 字符 串 的 开始 
进行 匹配 ， 对 其 他 号 码 从 字符 串 的 末尾 开始 进行 匹配 ; 将 括号 “0” 中 的 内 容 作为 一 个 原子 使 用 ; 使 用 
“\d” 来 匹配 一 个 数字 ， 区 号 为 3 或 4 个 数字 ， 其 他 数字 为 7 或 8 个 ,或 者 直接 判断 为 11 个 数字 ; 使 
用 “fy” 来 对 前 字符 进行 重复 匹配 ， 使 用 “|” 对 匹配 的 模式 进行 选择 ， 分 成 4 个 模式 。 

正则 表达 式 创建 完成 后 就 可 以 应 用 到 程序 中 对 电话 号 码 进 行 判 断 ， 要 完成 对 电话 号 码 的 判断 还 要 
应 用 到 一 个 preg_match() 函 数 。 

preg_match() 函 数 对 正则 表达 式 进行 匹配 。 返 回 匹配 的 次 数 ，0 次 (没有 匹配 ) 或 者 1 次 ， 如 果 出 
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错 则 返回 false。preg_match0 函 数 的 参数 说 明 如 表 6.5 所 示 。 


表 6.5 ”preg_match() 函 数 的 参数 说 明 

参数 说 了 明 
_patterm ”| 必要 参数 ， 指 定 匹 配 的 正则 表达 式 

subject | 必要 参数 ， 指 定 要 搜索 的 字符 串 
可 选 参数 ， 如 果 提 供 了 subpatterns， 则 其 会 被 搜索 的 结果 所 填充 。$ subpattems [0] 将 包含 与 整个 模式 
匹配 的 文本 ，$ subpatterns [1] 将 包含 与 第 一 个 捕获 的 括号 中 的 子 模式 所 匹配 的 文本 ， 以 此 类 推 
可 选 参数 ， 如 果 设 定 标记 PREG_OFFSET_CAPTURE， 则 每 个 出 现 的 匹配 结果 也 同时 返回 其 附属 的 字符 
串 偏 移 量 。 注意 这 改变 了 返回 的 数组 的 值 , 使 其 中 的 每 个 单元 也 是 一 个 数组 , 其 中 第 一 项 为 匹配 字符 串 ， 
第 二 项 为 其 偏 移 量 。 本 参数 自 PHP 4.3.0 开 始 使 用 


subpatterns 


flags 


最 后 将 正则 表达 式 和 preg_match0 函 数 应 用 到 实际 的 程序 中 , 实现 对 电话 号 码 格式 的 判断 。 这 里 以 
car_insert_ok.php 文件 中 的 代码 为 例 ， 关 键 代码 如 下 : 
例 程 16 ”代码 位 置 ， 光盘 \TM\06\wlgl\car_insert_ok.php 


<?php 
if($Submit==true){ // 判 断 表单 提交 的 值 
六 re9ty 相 梓 昱 由 应 用 Preg_match 函 数 和 正则 表达 式 判断 身份 证 号 码 格式 是 否 正确 *yyyyyyysyyyty 4 
ifpreg_match("Adfl7 IdIX]Ndf15} ,Suser_ number,Scounts)){ 
庆生 989884 李 应 用 preg_match 函 数 和 正则 表达 式 判断 电话 号 码 格式 是 否 正确 *ysysyeysyyyydyt 4 
ift(preg_match("/^(\d{3}-)(\d{8})$I^Qd{4}-)\d{7))8I Qad{4}-)(d{8})$/ ‘(Nd{11})$/",$user_tel,Scountes)){ 
让 weetwtxers 如 果 格式 正确 ， 则 执行 下 面 的 插入 语句 ， 将 车 辆 信息 添加 到 数据 库 中 ， 否 则 ****eeexss %/ 
$query=mysql_query("insert into 
tb_car(username,user_number,tel,address,car_number,car_road,car_content)values('$username','$user_number','$user_tel',$addr 
ess','$car_number','$car_road','$car_content")"); 
if($query=—true){ 
echo "<script>alert(' 车 源 信息 添加 成 功 !");window .location.hre 人 "indexs.php?Imbs= 车 源 信息 管理 


‘scrip>"; } 
}else{ 
echo "<script>alert(' 您 输入 的 电话 号 码 格式 不 正确 !!");history.back( 〇 </script>"; } 
}else{ 
/本 间 浊 于 于 于 于 于 于 半音 于 于 于 于 于 各 中华 于 和 站 半生 由 绢 出 提示 信息， 返回 到 表单 提交 页 ** 玉 闪闪 半球 六 六/ 
echo "<script>alert(' 您 输入 的 身份 证 号 码 的 格式 不 正确 !!");history.back()</script>"; } 

} 
D> 


6.11 ”报表 打印 技术 


报表 打印 技术 的 实现 方法 很 多 , 可 以 通过 Web 打印 、 通过 Word 打印 、 通过 Excel 打印 和 通过 CSS 
样式 打印 等 。 在 本 项 目 中 应 用 的 打印 方式 是 通过 Web 打印 ， 并 且 是 打印 指定 框架 中 的 内 容 ， 其 详细 的 
讲解 可 参考 6.6.5 节 发 货 单打 印 的 实现 过 程 。 下 面 再 介绍 一 种 通过 CSS 样式 来 打印 页 面 中 指定 内 容 的 
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通过 CSS 样式 打印 页 面 中 指定 内 容 主要 会 用 CSS 样式 的 media 类 型 。media 类 型 是 CSS 属性 媒体 
类 型 ， 用 于 直接 引入 媒体 的 属性 。 语 法 格式 如 下 : 
@media screen | print | projection | braille | aural | tv | handheld | all 
media 类 型 的 参数 说 明 如 表 6.6 所 示 。 
表 6.6 media 类 型 的 参数 说 明 


参数 说 了 明 
Screen 默认 值 ， 指 提交 到 计算 机 屏幕 
Print 指 输出 到 打印 机 

projection 指 提交 到 投影 机 

braille 提交 到 凸 字 触 觉 感知 设备 
aural 指 语音 电子 合成 器 

tv 电视 类 型 的 媒体 

handheld 指 手持 式 显示 设备 

all 用 于 所 有 媒体 


全 注意 : 应 用 CSS 样式 打印 ， 控 制 的 是 指定 表格 的 背景 ， 只 是 将 表格 的 背景 颜色 进行 隐藏 ， 而 不 能 
控制 表格 中 内 容 的 输出 。 所 以 在 应 用 CSS 样式 进行 指定 内 容 的 打印 时 ， 前 提 是 不 打印 的 内 
容 必 须 是 以 表格 中 背景 图 象 的 形式 显示 的 ， 否 则 应 用 CSS 样式 进行 指定 内 容 打印 是 没有 效 
果 的 。 


这 里 以 项 目 中 的 客户 信息 为 例 ， 创 建 一 个 css_print.php 文件 ， 讲 解 通过 CSS 样式 打印 指定 内 容 的 
操作 过 程 : 首先 编写 用 于 控制 指定 内 容 的 不 打印 CSS 样式 ， 程 序 代 码 如 下 : 


<style> 
@media print{ 
div{display:none} 
.bgnoprint{ 
background:display:none; 
上 
-noprint{ 
display:none 
} 
} 
body { 
margin-top: Opx; 
上 
</style> 


然后 设计 页 面 的 布局 ， 将 页 面 的 头 文件 和 尾 文件 以 插入 背景 图 片 的 方式 进行 实现 ， 连 接 数 据 库 ， 
应 用 while 循环 语句 输出 数据 库 中 的 客户 信息 ， 并 且 指 定 页 面 的 头 文件 和 尾 文件 为 不 打印 内 容 。 


<body class="bgnoprint"> 
二 应 用 bgnoprint 样 式 一 一 一 -一 一 一- 一 一 一- -> 


<table width="935" height="145" border="0" cellpadding="0" cellspacing="0"> 
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<tr> 
<!-- 设置 头 文件 ， 以 背景 图 像 的 形式 进行 输出 ， 并 且 应 用 bgnoprint 样 式 ， 控 制 该 背景 图 像 为 不 打印 的 内 容 --> 
<td background="images/index_03.gif" class="bgnoprint">&nbsp;</td> 


<htr> 
</table> 
一 一 一 一 --- 连 接 数据 库 ， 循 环 输出 数据 库 中 数据 -- 一 -一 一 一 一 一 一 -一 -一 -一 -一 -一 一 一 > 
<2php 
include("conn/conn.php"); /连接 数据 库 
$query=mysql_query("select * from tb_customer "); // 执 行 查询 语句 
while( $myrow=mysql_fetch_array($query) { /循环 输出 数据 库 中 的 内 容 
J 
<tr> 


<td height="26" align="center" bgcolor="#FFFFFF"><?php echo $myrow[customer_user];?></td> 
<td align="center" bgcolor="#FFFFFF"><?php echo $myrow[customer_tel];?></td> 
<td align="center" bgcolor="#FFFFFF"><?php echo $myrow[customer_address];?></td> 
<td align="center" bgcolor="#FFFFFF"><a hre 人 ="delete_customer.php?delete=<?php echo 
$myrow[customer_id];?>"> 删 除 </a></td> 
</tr> 
<2php }7> 
</table> 


最 后 设置 一 个 div 标签 ， 建 立 超 链接 ， 应 用 onclick 事件 调用 window.print() 方 法 和 printview() 函 数 
实现 页 面 的 打印 和 打印 预览 的 功能 。 
<!-- 设 置 超 链 接 ， 应 用 onclick 事 件 ， 调 用 window.print 方 法 执行 打印 ， 调 用 printview0 函 数 实现 打印 预览 的 功能 --> 
<t> 
<td height="26" colspan="4" align="center" bgcolor="#FFFFFF"><div><a href="#" onClick="window.print();"> 客 
户 详 单打 印 </a>&nbsp;<a hre 伍 "#" onClick="printview();"> 打 印 预览 </a></div></td> 
</t> 


通过 CSS 样式 实现 页 面 中 指定 内 容 打 印 的 运行 结果 如 图 6.40 和 图 6.41 所 示 。 


物流 配送 信 筷 网 
客户 姓名 电话 联系 地 址 操作 
ek 0431-12345678 长 春 市 删除 
李 #* 13604338784 四 平市 删除 
客户 详 单打 印 打印 预览 
全 物流 配送 信息 网 版 权 所 有 


图 6.40 客户 信息 打印 页 面 的 运行 结果 
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印 预览 x| 
打印 外 ..， | 得 | * “页面 WwW 上 共 t | 伯父]10% 可 | 禹 的 | 关闭 名 
| 客户 姓名 电话 ] 联系 地 址 = 
| 刘 k* 0431-12345678 | 长 春 市 
李 *#* 13604338784 | 四 平市 | 


6.41 客户 信息 打印 预览 页 面 的 的 运行 结果 


技巧 ， 在 进行 Web 打印 时 ， 可 以 通过 以 下 操作 控制 是 否 打 印 背 景 颜色 和 图 像 。 在 ]E 窗口 中 ， 选 
择 “ 工 具 ”/“Internet 选项 ”命令 ， 在 弹出 的 “Internet 选项 ”对 话 框 中 选择 “高 级 ”选项 
卡 ， 在 “设置 ”列表 中 设置 “打印 背景 颜色 和 图 像 ”前 面 的 复 选 框 是 否 选中 ， 如 果 选 中 ， 
代表 打印 背景 颜色 和 图 像 ， 否 则 不 打印 背景 闫 色 和 图 像 。 


6.12 ”本 章 总 结 


本 章 从 某 物流 配送 公司 的 实际 需求 角度 出 发 ， 开 发 一 个 完整 的 物流 配送 信息 管理 系统 ， 详 细 地 讲 
解 了 物流 配送 信息 网 的 开发 流程 ， 从 最 初 的 需求 分 析 、 可 行 性 分 析 ， 到 系统 的 设计 、 数 据 库 的 设计 ， 
其 中 重点 突出 车 源 信息 查询 模块 、 发 货 单 管理 模块 和 回执 单 验 收 管理 模块 的 设计 。 通 过 本 章 的 学 习 ， 
读者 不 但 可 以 了 解 物流 配送 系统 开发 的 整体 思路 ， 而 且 能 够 掌握 很 多 关键 的 技术 和 技巧 : 函数 的 灵活 
运用 ，MySQL 存储 过 程 的 创建 和 应 用 ;报表 打印 技术 的 实现 ;应 用 正则 表达 式 验证 电话 号 码 等 。 
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学 校 图 书馆 管理 系统 


( Apache+PHP+phpMyAdmin+MySQL 5.0 实现 ) 


随 着 网 络 技术 的 高 速 发 展 和 计算 机 应 用 的 普及 ,利用 计算 机 对 图 书馆 的 日 常 工 
作 进 行 管理 势 在 必 行 。 虽 然 目前 很 多 大 型 的 图 书馆 已 经 有 一 整套 比较 完善 的 管理 系 
统 ， 但 是 在 一 些 中 小 型 的 图 书馆 中 ， 大 部 分 工作 仍 需 由 手工 完成 ， 工 作 起 来 效率 比 
较 低 ， 管 理 员 不 能 及 时 了 解 图 书馆 内 各 类 图 书 的 借阅 情况 ， 读 者 需要 的 图 书 难以 在 
短 时 间 内 找到 ， 不 便于 动态 及 时 地 调整 图 书 结构 。 为 了 更 好 地 适应 当前 读者 的 借阅 
需求 ， 解 决 手工 管理 中 存在 的 许多 坏 端 ， 越 来 越 多 的 中 小 型 图 书馆 正在 逐步 向 计算 
机 信息 化 管理 转变 。 本 章 通过 开发 一 个 流行 的 图 书馆 管理 系统 ， 为 读者 讲解 详细 的 
项 目 开发 流程 。 通 过 阅读 本 章 ， 可 以 学 习 到 : 


图 书馆 管理 系统 天 发 的 基本 过 程 
系统 设计 的 方法 

如 何 分 析 并 设计 数据 库 、 数 据 表 
多 表 查 询 的 方法 
面向 对 象 的 编程 方法 

主要 功能 模块 的 实现 方法 

单元 测试 的 方法 

如 何 自动 计算 图 书 归 还 日 期 

内 联接 和 外 联接 语句 的 使 用 方法 


豆 吾 吾 于 于 于 于 于 至 
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7.1 开发 青 景 


博 考 图 书馆 是 一 家 吉林 XX 师范 学 校 的 大 型 图 书馆 。 随 着 学 校 图 书馆 规模 的 不 断 壮大 ， 经 营 的 图 
书 品种 、 数 量 也 逐渐 增多 。 在 学 校 图 书馆 不 断 发 展 的 同时 ， 校 图 书馆 常年 采用 的 传统 的 人 工 方式 管理 
暴露 了 一 些 问 题 。 例 如 ， 碍 找 读 者 借阅 的 某 一 本 图 书 的 具体 摆 放 位 置 ， 需 要 靠 人 工 记 忆 在 书 海中 苦 苦 
查找 ， 由 于 图 书 储存 量 大 ， 很 难 准确 定位 图 书 的 具体 位 置 ， 因 此 每 天 都 要 浪费 大 量 宝贵 的 时 间 资 源 。 
学 校 图 书馆 为 提高 工作 效率 ， 同 时 摆脱 图 书 管理 人 员 在 工作 中 出 现 的 种 种 束 端 ， 现 需要 委托 某 单位 开 
发 一 个 学 校 图 书馆 管理 系统 。 


7.2 ”需求 分 析 


通过 计算 机 对 图 书 进行 管理 ， 不 仅 为 图 书馆 的 管理 注入 了 新 的 生机 ， 而 且 在 运营 过 程 中 节省 了 大 
量 的 人 力 、 物 力 、 财 力 和 时 间 ， 可 以 提高 图 书馆 的 效率 ， 还 为 图 书馆 在 读者 群 中 树立 了 一 个 全 新 的 形 
象 ， 为 图 书馆 日 后 发 展 英 定 一 个 良好 的 基础 。 通 过 对 一 些 大 型 图 书馆 的 实际 考察 、 分 析 ， 并 结合 图 书 
馆 的 要 求 以 及 实际 的 市 场 调查 ， 要 求 本 系统 具有 以 下 功能 : 

网 站 设计 页 面 要 求 美观 大 方 、 个 性 化 ， 功 能 全 面 ， 操 作 简单 。 

要 求实 现 基 础 信息 的 管理 平台 。 

要 求 对 所 有 读者 进行 管理 。 

要 求实 现 图 书 借阅 排行 、 了 解 当前 的 畅销 书 。 

商品 分 类 详尽 ， 可 按 不 同类 别 查看 图 书信 息 。 

提供 快速 的 图 书信 息 、 图 书 借阅 检索 功能 ， 保 证 数据 查询 的 灵活 性 。 

实现 图 书 借阅 、 图 书 续 借 、 图 书 归还 的 功能 。 

实现 综合 条 件 查 询 ， 如 按 用 户 指定 条 件 查询 、 按 日 期 时 间 段 查询 、 综 合 条 件 查询 等 。 
要 求 图 书 借阅 、 续 借 、 归 还 时 记 下 每 一 笔记 录 的 操作 员 。 

实现 对 图 书 借阅 、 续 借 和 归还 过 程 的 全 程 数据 信息 跟踪 。 

提供 借阅 到 期 提醒 功能 ， 使 管理 者 可 以 及 时 了 解 到 已 经 到 达 归 还 日 期 的 图 书 借阅 信息 。 
提供 灵活 、 方 便 的 权限 设置 功能 ， 使 整个 系统 的 管理 分 工 明确 。 

有 具 有 易 维护 性 和 易 操 作 性 。 


办 办 办 办 办 办 办 办 办 办 多 


7.3 系统 设计 


7.3.1 系统 目标 


根据 前 面 所 作 的 需求 分 析 及 用 户 的 需求 可 以 得 出 ,学 校 图 书馆 管理 系统 实施 后 ， 应 达到 以 下 目标 : 
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网 站 设计 页 面 要 求 美观 大 方 、 功 能 全 面 ， 操 作 简 单 。 

网 站 整体 结构 和 操作 流程 合理 顺畅 ， 实 现 人 性 化 设计 。 
规范 、 完 善 的 基础 信息 设置 。 

对 操作 员 设 置 不 同 的 操作 权限 ， 为 管理 员 提供 修改 权限 功能 。 
对 所 有 读者 进行 集中 管理 。 

对 图 书信 息 进 行 集中 管理 。 

实现 图 书 借阅 排行 ， 以 便 了 解 当前 的 畅销 书 。 

提供 快速 的 图 书信 息 、 图 书 借阅 检索 功能 。 

实现 图 书 借阅 、 图 书 续 借 、 图 书 归还 功能 。 

实现 综合 条 件 查询 ， 如 按 用 户 指定 条 件 查 询 、 按 日 期 时 间 段 查询 、 综 合 条 件 查询 等 。 
实现 图 书 借阅 、 续 借 、 归 还 时 记 下 每 一 笔记 录 的 操作 员 。 
支持 图 书 到 期 提醒 功能 。 

为 操作 员 提供 密码 修改 功能 。 

系统 运行 稳定 、 安 全 可 靠 。 


因 办 办 因 办 办 办 办 办 办 办 办 凶 轨 


7.3.2 系统 功能 结构 


根据 学 校 图 书馆 管理 系统 的 特点 ， 可 以 将 其 分 为 系统 设置 、 读 者 管理 、 图 书 档案 管理 、 图 书 借 还、 


系统 查询 等 5 个 部 分 ， 其 中 各 个 部 分 及 其 包括 的 具体 功能 模块 如 图 7.1 所 示 。 


学 校 图 书馆 管理 系统 
图 书 档案 管理 


苇 障 副 诸 水 故 
副 澡 洲 旦 西 赤 


读 图 
加 者 书 
二 类 档 
0 型 案 
由 管 查 

理 询 


图 7.1 学 校 图 书馆 管理 系统 功能 结构 图 
7.3.3 ”系统 流程 图 


学 校 图 书馆 管理 系统 的 流程 如 图 7.2 所 示 。 


Sa 
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vy 


| 图 书 借阅 | | 图 书 续 借 | 图 书 归还 | 
[ | 


管理 图 书 档案 信息 | 


管理 读者 档案 信息 


完成 图 书 续 借 


根据 读者 信息 获 
取 借 阅 图 书信 息 


完成 图 书 借阅 


归还 相关 图 书 


图 7.2 学 校 图 书馆 管理 系统 流程 图 


获取 读者 信息 


7.3.4 系统 预览 


学 校 图 书馆 管理 系统 由 多 个 程序 页 面 组 成 ， 下 面 仅 列 出 儿 个 典型 页 面 ， 其 他 页 面 参见 光盘 中 的 源 
程序 。 

系统 登录 页 面 如 图 7.3 所 示 ， 该 页 面 用 于 实现 管理 员 登 录 。 系 统 首页 如 图 7.4 所 示 ， 该 页 面 用 于 实 
现 显示 系统 导航 、 图 书 借阅 排行 和 版 权 信息 等 功能 。 


@@ 二 二 图 专 综 管理 系统 


© sen 
io BRARY wo ee 三 J 村 己 己 江 负 持 行 榜 BookBorowSor 
二 全 
A 


ar el 


图 7.3 系统 登录 (光盘 \TM\07\library\login.php) 图 7.4 系统 首页 (光盘 \TMW7ibraryindex.php) 
图 书 借阅 页 面 如 图 7.5 所 示 ， 该 页 面 用 于 实现 图 书 借阅 功能 。 图 书 借 阅 查 询 页 面 如 图 7.6 所 示 ， 该 
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页 面 用 于 实现 按照 复合 条 件 查询 图 书 借阅 信息 。 


(《 国 1 二 辣 从 管理 系统 (Ei 


图 7.5 图 书 借阅 (光盘 \TM\07\library\bookBorrow.php) ”图 7.6 图书 借阅 查询 (光盘 \TM\07\library\borrowQuery.php) 
7.3.5 开发 环境 


在 开发 学 校 图 书馆 管理 系统 时 ， 该 项 目 使 用 的 软件 开发 环境 如 下 : 
1. 服务 器 端 

操作 系统 : Windows 2003 Server/Linux (推荐 ) 。 
服务 器 : Apache 2.2。 

PHP 软件 : PHP 5.1.6。 

数据 库 : MySQL 5.0.24。 

MySQL 图 形 化 管理 软件 : phpMyAdmin-2.9.0.2。 
开发 工具 : Dreamweaver 8。 

浏览 器 : IE 6.0 及 以 上 版 本 。 

分 辩 率 : 最 佳 效 果 1024X 768 像素 。 

客户 端 

浏览 器 : IE 6.0 及 以 上 版 本 。 

分 辨 率 : 最 佳 效 果 1024X 768 像素 。 


7.3.6 文件 夹 组 织 结构 


办 办 办 办 办 国 多 轨 


Bs 


| 


在 编写 代码 之 前 ， 可 以 把 系统 中 可 能 用 到 的 文件 夹 先 创建 出 来 例如， 创建 一 个 名 为 Images 的 文 
件 夹 ， 用 于 保存 网 站 中 所 使 用 的 图 片 》， 这 样 不 但 可 以 方便 以 后 的 开发 工作 ， 也 可 以 规范 网 站 的 整体 
架构 。 笔 者 在 开发 学 校 图 书馆 管理 系统 时 ,设计 了 如 图 7.7 所 示 的 文件 夹 组 织 结构 图 。 在 开发 时 ， 只 需 
要 将 所 创建 的 文件 保存 在 相应 的 文件 夹 中 就 可 以 了 。 
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日 回 litrary 
同 -mm 一 用 于 存 镭 网 站 使 用 的 数据 库 连 接 文件 
四 “= 一 一 一 一 一 一 一 一 一 一 一 一 用 于 存 佬 网 站 使 用 的 CS 样式 表 
局 data 用 于 存储 网 站 使 用 的 数据 库 文件 
BB Images 用 于 存 鱼 网 站 使 用 的 图 片 资源 文件 
名 用 于 存 导 网 站 使 用 的 JavaScript 脚 本 文件 


图 7.7 文件 夹 组 织 结构 
7.4 数据 库 设 计 
学 校 图 书馆 管理 系统 是 一 个 数据 库 开发 的 Web 网 站 。 下 面 对 学 校 图 书馆 使 用 的 数据 库 进行 分 析 和 
介绍 。 
7.4.1 数据 库 分 析 


由 于 本 系统 是 为 中 小 型 的 图 书馆 开发 的 程序 ， 需 要 充分 考虑 到 成 本 问题 及 使 用 需求 〈 如 跨 平 台 ) 
等 问题 ， 而 MySQL 是 世界 上 最 为 流行 的 开放 源码 的 数据 库 ， 是 完全 网 络 化 的 跨 平台 的 关系 型 数据 库 
系统 ， 这 正好 满足 了 中 小 型 企业 的 需求 ， 所 以 本 系统 采用 MySQL 数据 库 。 


7.4.2 数据 库 概念 设计 
根据 以 上 各 节 对 系统 所 做 的 需求 分 析 、 系 统 设计 ， 规 划 出 本 系统 中 使 用 的 数据 库 实 体 分 别 为 图 书 档案 
实体 、 读 者 档案 实体 、 借 阅 档案 实体 、 归 还 档案 实体 和 管理 员 实体 。 下 面 将 介绍 几 个 关键 实体 的 E-R 图 。 
1. 图 书 档案 实体 


图 书 档案 实体 包括 编号 、 条 形 码 、 书 名 、 类 型 、 作 者 、 译 者 、 出 版 社 、 价 格 、 页 码 、 书 架 、 录 入 
时 间 和 操作 员 等 属性 。 图 书 档案 实体 的 E-R 图 如 图 7.8 所 示 。 


SS 


图 7.8 图 书 档案 实体 E-R 
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2. 读者 档案 实体 
读者 档案 实体 包括 编号 、 姓 名 、 性 别 、 条 形 码 、 职 业 、 出 生日 期 、 有 效 证 件 、 证 件 号 码 、 电 话 、 
电子 邮件 、 登 记 日 期 、 操 作 员 、 类 型 和 备注 等 属性 。 读 者 档案 实体 的 E-R 图 如 图 7.9 所 示 。 


图 7.9 读者 档案 实体 E-R 图 


3， 借阅 档案 实体 
借阅 档案 实体 包括 编号 、 读 者 编号 、 图 书 编号 、 借 书 时 间 、 应 还 时 间 、 操 作 员 和 是 否 归 还 等 属性 。 
借阅 档案 实体 的 E-R 图 如 图 7.10 所 示 。 


图 7.10 借阅 档案 实体 E-R 图 


4. 归还 档案 实体 
归还 档案 实体 包括 编号 、 读 者 编号 、 图 书 编号 、 归 还 时 间 和 操作 员 等 属性 。 归 还 档案 实体 的 E-R 
图 如 图 7.11 所 示 。 


操作 员 


图 7.11 归还 档案 实体 E-R 图 
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7.4.3 创建 数据 库 及 数据 表 


结合 实际 情况 及 对 用 户 需 求 的 分 析 , 学 校 图 书馆 管理 系统 db_library 数据 库 主 要 包含 如 下 9 个 数据 


表 ， 如 图 7.12 所 示 。 


图 服务 器 : localhost ， 昌 数据 库 : db_library 

表 类 型 整理 说 明 
th_bookcase MyISAM gb2312_chinese_ci 图 书 书架 信息 表 
tb_bookinfo MylSAM gb2312_chinese_ci 图 书信 息 表 
tb_borrow MylSAM ”gb2312_chinese_ci 图 书 借阅 信息 表 
tb_library MylISAM ”gb2312_chinese_ci ”图 书馆 信息 表 
tb_manager ”MylSAM “gb2312_chinese_ci ”管理 员 信息 表 
tb_parameter MylSAM ”gb2312_chinese_ci 参数 设置 信息 表 
th_publishing MylISAM gb2312_chinese_ci 出 版 社 信息 表 
th_purview MylSAM ”gb2312_chinese_ci ”权限 信息 表 
tb_reader MyISAM ”gb2312_chinese_ci ”读者 信息 表 
tb_readertype MylSAM ”gb2312_chinese_ci ”读者 类 型 信息 表 

图 7.12 学 校 图 书馆 管理 系统 数据 表 


结合 该 数据 表 的 创建 方法 ， 读 者 可 以 自行 创建 以 下 数据 表 。 数 据 表 的 设计 结构 如 图 7.13 一 图 7.15 


所 示 。 


1. tb_bookinfo (图 书信 息 表 ) 
图 书信 息 表 主 要 用 于 存储 图 书 的 基础 信息 。 该 数据 表 的 结构 如 图 7.13 所 示 。 


字段 类 型 
barcode Yarchar(30) 


bookname varchar(70) 
typeid int(10) 

author Yarchar(30) 
translator Yarchar(30) 


ISBN varchar(20) 
price loat(8,2) 
page int(10) 


bookcase int(10) 
Storage int(10) 
inTime date 
operator varchar(30) 
del tinyint() 

过 int(11) 


整理 Null ”默认 


gb2312_chinese_ci 
gb2312_chinese_ci 


gb2312_chinese_ci 


gb2312_chinese_ci 
gb2312_chinese_ci 


gb2312_chinese_ci 


各 和 各 和 和 和 到 
同 
车 


加 站 
本 
E 


加 加 加 
le 
E 瞪 


加 加 


NULL 
NULL 


胃 服务 器 : localhost 〉 晶 数据 库 : db_library 图 表 : tb_bookinfo 
额外 


auto_increrment 


说 明 
图 书 条 形 码 
图 书 名 称 
图 书 类 型 
图 书 作者 
图 书 译 者 


图 7.13 图 书信 息 表 结构 
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2. tb_borrow (图 书 借阅 信息 表 ) 
图 书 借阅 信息 表 主 要 用 于 存储 图 书 的 借阅 信息 。 该 数据 表 的 结构 如 图 7.14 所 示 。 


转 服务 器 : localhost ， 曲 数据 库 : db_library ， 国 
字段 类 型 整理 Null ”默认 
这 intt10) 否 
readerid int(10) 是 NULL 
bookid int(10) 是 NULL 
borrowTime date 是 NULL 
backTime 。 date 是 NULL 
operator varchar(30) gb2312_chinese_ci 是 NULL 
ifback tinyint(1》 是 0 


表 :tb_borrow 


家 外 


auto_increment 


说 明 
自动 编号 记 
读者 jl 编号 
图 书 i 编号 
图 书 惜 阅 时 间 
图 书 归 还 时 间 
操作 员 
是 否 归还 


图 7.14 图 书 借阅 信息 表 结 构 


3. tb_reader (读者 信息 表 ) 
读者 信息 表 主 要 用 于 存储 用 户 的 读者 的 基础 信息 。 该 数据 表 的 结构 如 图 7.15 所 示 。 


字段 


barcode 
Vocation 
birthday 
paperType 
paperNO 
tel 

email 
createDate 
operator 
remark 
typeid 


类 型 
int(10) 
Yarchar(20) 
Varchar(4) 
varchar(30) 
varchar(s0) 
date 
yarchar(10) 
varchar(20) 
varchar(20) 
varchart100) 
date 
Yarchar(30) 
mediumtext 
intt11) 


9b2312_chinese_ci 
gb2312_chinese_ci 
gb2312_chinese_ci 
gb2312_chinese_ci 


gb2312_chinese_ci 
gb2312_chinese_ci 
yb2312_chinese_ci 
gb2312_chinese_ci 


yb2312_chinese_ci 
yb2312_chinese_ci 


汉 加 加 汉 加 汉 和 加 和 汉 汉 汉 叹 


闸 


默认 


NULL 
NULL 
NULL 
NULL 
NULL 
NULL 
NULL 
NULL 


国 服务 器 : localhost ， 虽 数据 库 : db_library ， 国 表 :tb_reader 


客 外 
auto_increment 


说 明 

自动 编号 这 
读者 姓名 
性 别 
读者 条 形 码 
读者 职业 
出 生日 期 
读者 证 件 
证 件 号 码 
读者 电话 
E-mail 也 址 
办 卡 时 间 
操作 员 
备注 

读者 类 型 


图 7.15 读者 信息 表 结构 


[0 说 明 : 限于 篇 幅 ， 笔 者 在 此 只 给 出 较 重要 的 数据 表 ， 其 他 数据 表 参 见 本 书 附带 的 光盘 


RS 
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7.5 首页 设计 


7.5.1 首页 概述 


管理 员 通过 “系统 登录 ”模块 的 验证 后 ， 可 以 登录 到 图 书馆 管理 系统 的 首页 。 系 统 首页 主要 包括 
导航 栏 、 排 行 榜 和 版 权 信息 3 部 分 。 其 中 ， 导 航 栏 中 的 功能 菜单 将 根据 登录 管理 员 的 权限 进行 显示 。 
例如 ， 系 统管 理 员 Tsoft 登录 后 ， 将 拥有 整个 系统 的 全 部 功能 ， 因 为 它 是 超级 管理 员 。 

下 面 看 一 下 本 案例 中 提供 的 系统 首页 ， 该 页 面 在 本 书 光盘 中 的 路 径 为 \TM\07\library\index.php， 如 
图 7.16 所 示 。 


而 和 系 
= 
当前 登录 的 用 户 : Tsoft 


首页 。 系统 设置 。 读者 管理 。 图 书 档案 管理 。 图 书 异 还 。 系统 查询 。 更 改口 令 。 注销 


司 |] 肛 上 思 志 借阅 排行 榜 有 
图 书 条 形 码 图 书 名 称 图 书 类 型 书架 出 版 社 作者 定价 元) 借阅 次 数 


987654321 ”PE 函数 参考 大 全 宝典 系列 HE 书架 ”人 民 邮 电 出 版 社 邹 **、 张 习 98.00 3 
123456789 ” PIF 数据 库 系统 开发 完全 手册 ”数据 库 技 术 。 PIF 书架 ”人 民 闻 也 出 版 社 汪 **、 刘 和 65.00 3 
123454321 ”PP 程序 开发 范例 宝典 宝典 系列 PF 书架 pe ee 89.00 1 
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本 站 请 使 用 IF 6.0 或 以 上 版 本 1024T66 为 景 佳 显示 效果 版 权 信息 


7.16 ”学校 图 书馆 管理 系统 首页 


7.5.2 首页 技术 分 析 


学 校 图 书馆 管理 系统 是 一 个 功能 全 面 、 大 型 的 Web 网 站 ， 通 过 对 网 站 的 安全 性 考虑 ， 本 网 站 对 该 
系统 进行 权限 的 分 配 ， 只 有 管理 员 级 别 的 超级 用 户 可 以 对 普通 用 户 的 权限 进行 管理 和 设置 。 系 统 首页 
主要 通过 判断 管理 员 的 权限 来 显示 该 用 户 所 操作 的 功能 模块 ， 关 键 代 码 如 下 : 

例 程 01 ”代码 位 置 ， 光盘 \TM\07\librarynavigation.php 


<?php 
session_start(); // 初 始 化 session 变 量 
include("conn/conn.php"); // 连 接 数 据 库 文件 


$query=mysql_query("select m.id,m.name,p.id,p.sysset,p.readerset,p.bookset,p.borrowback,p.sysquery from tb_manager 
。341 。 


PHP 项 目 开发 全 程 实录 


as m left join (Select * from tb purview ) as p on m.id=p.id where name='$ SESSION[admin name]"); 

S$info=mysql_fetch_array($query):; // 检 索 用 户 权限 

> 

<!-- 检 索 用 户 所 对 应 的 权限 ， 如 果 权限 值 为 1， 则 说 明 该 功能 可 用 ， 并 输出 到 浏览 器 ， 否 则 不 显示 -> 

<td width="70%" align="right"> 

<ahre 人 "index.php" class="al"> 首 页 </a> | 

<?php if($info[sysset]==1){ ?><a ‘onmouseover=showmenu(event,sysmenu) onmouseout=delayhidemenu() 
style="CURSOR:hand" class="al"> 系 统 设置 </a> | <?php}?> 

<?php if($info[readerset]—1){?><a ‘onmouseover=showmenu(event,readermenu) onmouseout=delayhidemenu() 
style="CURSOR:hand" class="al"> 读 者 管理 </a> | <?php}?> 

<?php if(Sinfo[booksetl 一 TD){ ?><a hre 人 "book.php" class="al"> 图 书 档案 管理 </a> | <?php }?> 

<?php if($info[borrowback]==1){?><a onmouseover=showmenu(event,borrowmenu) onmouseout=delayhidemenu() 
style="CURSOR:hand"class="al" > 图 书 借 还 </a> | <?php }?> 

<?php if(Sinfo[sysquery]==1){ ?><a ‘onmouseover=showmenu(event,querymenu) onmouseout=delayhidemenu() 
style="CURSOR:hand" class="al"> 系 统 查询 </a> | <?php}?> 

<a href="pwd_Modify.php" class="al"> 更 改口 令 </a> | 

<a href="safequit.php" class="al"> 注 销 </a> 

</td> 


[0 说 明 : 在 权限 信息 表 tb_purview 中 ， 权 限 值 为 1， 代表 具备 该 模块 的 操作 权限 ; 权限 值 为 0， 代表 
不 具备 该 模块 的 操作 权限 。 
在 实现 系统 导航 菜单 时 ， 引 用 了 JavaScript 文件 menu.JS， 该 文件 中 包含 全 部 实现 半 透 明 背 景 菜单 
的 JavaScript 代码 。 


六 技巧 : 将 页 面 中 所 涉及 的 JavaScript 代码 保存 在 一 个 单独 的 JS 文件 中 ， 然 后 通过 <script></script> 将 
其 引用 到 需要 的 页 面 ， 可 以 规范 页 面 代 码 。 在 系统 导航 页 面 引用 menu.JS 文件 的 代码 如 下 : 


<script sre="JS/menu.JS"></script> 
7.5.3 首页 的 实现 过 程 


系统 首页 的 内 容 显示 区 用 于 显示 图 书 的 排行 信息 ， 并 将 排行 结果 按 借阅 数量 降序 排列 。 该 页 的 关 
键 代码 如 下 : 

例 程 02 ”代码 位 置 ， 光盘 \TM\07\library\index.php 

<?php 

include("conn/conn.php"); // 连 接 数 据 源 文件 

$sql=mysql query("select * from (select bookid,count(bookid) as degree from tb borrow group by bookid) as borr join 
(select b.*,c.name as bookcasename,p.pubname,t.typename from tb_bookinfo b left join tb_bookcase ¢ on b.bookcase=c.id join 


tb publishing p on b.ISBN=p.ISBN join tb booktype t on b.typeid=t.id where b.del=0) as book on borr.bookid=book.id order 
by borr.degree desc limit 10"); 


$info=mysql fetch_array($sql); // 检 索 图 书 借阅 信息 

$i=1; 

dof /应 用 do…while 循 环 语句 显示 图 书信 息 
> 

<tr> 


<td height="25" align="center"><?php echo $i;7?></td> 
<td style="padding:Spx;">&nbsp;<?php echo $info[fbarcode];?></td> 


RS 
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<td style="padding: 5px:;"><?php echo $info[bookname]:?></td> 

<td style="padding:5px;"><?php echo $info[typename];?></td> 

<td align="center">&nbsp:<?php echo $info[bookcasename]:?></td> 
<td align="center">&nbsp;<?php echo $info[pubname];?></td> 

<td align="center"><?php echo $info[author];?></td> 

<td align="center"><?php echo S$info[price];?></td> 

<td align="center"><?php echo S$info[degreel];?></td> 


</tr> 
<?php 
$i=$i+1; /变量 自 加 1 操作 
}while(Sinfo=mysql_fetch_array(SsqD); //do…while 循 环 语句 结束 
> 


7.6 管理 员 模 块 设计 


7.6.1 管理 员 模 块 概述 


管理 员 模 块 主要 包括 管理 员 登 录 、 查 看 管理 员 列 表 、 添 加 管理 员 信息 、 管 理 员 权限 设置 、 管 理 员 
删除 和 更 改口 令 等 6 个 功能 。 管 理 员 模块 的 框架 如 图 7.17 所 示 。 


管理 员 列表 
| 


+ Y Y Y 


添加 管理 员 | | 权限 设置 | ET | 更 改口 令 


图 7.17 管理 员 模块 的 框架 图 
7.6.2 ”管理 员 模 块 技术 分 析 
在 管理 员 模 块 中 , 涉及 到 的 数据 表 是 tb_manager (管理 员 信息 表 ) 和 tb_purview (权限 表 ) 。 其 中 ， 


管理 员 信 息 表 中 保存 的 是 管理 员 名 称 和 密码 等 信息 ， 权 限 表 中 保存 的 是 各 管理 员 的 权限 信息 ， 这 两 个 
表 通 过 各 自 的 id 字段 相关 联 。 通 过 这 两 个 表 可 以 获得 完整 的 管理 员 信息 。 
“gp 
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全 注意 : 在 实现 系统 登录 前 ,需要 在 MySQL 数据 库 中 ， 手 动 添加 一 条 系统 管理 员 的 数据 ( 管理 员 名 
为 Tsoft、 密 码 为 111、 拥 有 所 有 权限 ) ， 即 在 MySQL 的 客户 端 命令 行 中 应 用 下 面 的 语句 分 
别 向 管理 员 信息 表 tb_manager 和 权限 表 tb_purview 中 各 添加 一 条 数据 。 
# 添 加 管理 员 信息 
insert into tb manager (name,pwd) values(Tsoft,1117); 
# 添 加 权限 信息 
insert into tb_purview values(1,1,1,1,1,1); 
从 网 站 安全 的 角度 考虑 ， 仅 仅 有 上 面 介绍 的 系统 登录 页 面 并 不 能 有 效 地 保存 系统 的 安全 ， 一 旦 系 
统 首页 面 的 地 址 被 他 人 获得 ， 就 可 以 通过 在 地 址 栏 中 输入 系统 的 首页 面 地 址 而 直接 进入 到 系统 中 。 为 
了 便于 网 站 的 维护 ， 因 此 将 验证 用 户 是 否 登 录 的 代码 封装 在 独立 的 PHP 文件 中 ， 即 check_login.php 文 
件 。 验 证 用 户 是 否 登 录 的 具体 代码 如 下 : 


例 程 03 ”代码 位 置 ， 光盘 \TM\07\library\check_login.php 


<?php 
session_start(); /初始 化 session 变 量 
if($_SESSION[admin_name]=—""){ /如 果 session 变 量 为 室 ， 则 说 明 用 户 未 登录 


echo "<script>alert(' 对 不 起 ， 请 通过 正确 的 途径 登录 博 考 图 书馆 管理 系 
统 !"");window .location.href='login.php';</script>"; 


} 
> 


当 系 统 调用 首页 时 ， 会 判断 session 变量 admin_name 是 否 存在 ， 如 果 不 存在 ， 将 页 面 重 定向 到 系 
统 登 录 (login.php) 页 面 。 


7.6.3 ”系统 登录 的 实现 过 程 


国 系统 登录 使 用 的 数据 表 : tb_manager 

系统 登录 是 进入 学 校 图 书馆 管理 系统 的 入 口 ， 主 要 用 于 验证 管理 员 的 身份 。 运 行 本 系统 ， 首 先进 
入 的 是 系统 登录 页 面 ， 在 该 页 面 中 ， 系 统管 理 员 可 以 通过 输入 正确 的 管理 员 名 称 和 密码 登录 到 系统 首 
页 ， 当 用 户 没有 输入 管理 员 名 称 或 密码 时 ， 系 统 会 通过 JavaScript 进行 判断 ， 并 给 予 信息 提示 。 系 统 登 
录 页 面 的 运行 结果 如 图 7.18 所 示 。 


例 ) 二 同方 包 管理 系 


BO KAO LIBRARY Ms were 


EE 


ES cr 
Ee ES 


7.18 ”系统 登录 页 面 的 运行 结果 


RS 
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系统 登录 页 面 主要 用 于 收集 管理 员 的 输入 信息 及 通过 自 定 义 的 JavaScript 函数 验证 输入 信息 是 否 


为 空 。 该 页 面 中 所 涉及 到 的 表单 元 素 如 表 7.1 所 示 。 


表 7.1 系统 登录 页 面 所 涉及 的 表单 元 素 


名 称 重要 属性 含义 
forml method="post" action="chklogin.php" 管理 员 登 录 表单 
name Size="25" 管理 员 名 称 
pwd Password size="25" 管理 员 密 码 
submit submit value=" 确 定 " onclick="return check(form1)" “确定 ”按钮 
submit3 reset value=" 重 置 " “ 重 置 ”按钮 
submit2 button value=" 关 闭 " onClick="window.close():" “关闭 ”按钮 


编写 自 定义 的 JavaScript 函数 ， 用 于 判断 管理 员 名 称 和 密码 是 否 为 空 。 代 码 如 下 : 
例 程 04 ”代码 位 置 ， 光盘 \TM\07\library\login.php 


<script language="javascript"> 


function check(form){ // 自 定义 一 个 JavaScript 函 数 check() 
if (form.name.value=—""){ /如 果 管 理 员 名 称 为 室 ， 则 弹出 提示 信息 ， 并 重新 返回 焦点 
alert(" 请 输入 管理 员 名 称 !");form.name.focus():return false; 
} 
if (form.pwd.value==""){ // 如 果 管 理 员 密 码 为 空 ， 则 弹出 提示 信息 ， 并 重新 返回 焦点 


alert(" 请 输入 密码 !");form.pwd.focus(;returm false; 
} 
} 
</script> 


提交 表单 到 数据 处 理 页， 页 面 中 为 了 防止 非法 用 户 进入 学 校 图 书馆 管理 系统 首页 ， 通 过 调用 类 


chkinput() 方 法 实现 判断 用 户 名 和 密码 是 否 正 确 。 如 果 为 合法 用 户 ， 则 可 以 登录 学 校 图 书馆 管理 系统 的 
首页 ， 耕 则 ， 弹 出 相应 的 错误 提示 。 关 键 代 码 如 下 : 


例 程 05 ”代码 位 置 ， 光盘 \TM\07\library\chklogin.php 
<?php 


session_start(); // 初 始 化 session 变 量 
$A_name=$_POST[name]; // 接 收 表 单 提交 的 用 户 名 
$A_pwd=$_POST[pwd]; /接收 表单 提交 的 密码 
class chkinput{ /定义 类 
var $name; 
var $pwd; 
function chkinput($x,$y){ 定义 一 个 方法 
S$this->name=$x; // 将 管理 员 名 称 传 给 类 对 象 $this->name 
S$this->pwd=$y; // 将 管理 员 密 码 传 给 类 对 象 $this->pwd 
4 
function checkinputO{ 
include("conn/conn.php"); // 连 接 数 据 库 文件 
$sql=mysql query("select * from tb manager where name=".$this->name." and pwd=".$this->pwd."",$conn); 
S$info=mysql_fetch_array($sq]); /检索 管理 员 名 称 和 密码 是 否 正确 
if($info—false){ // 如 果 管 理 员 名 称 或 密码 不 正确 ， 则 弹出 相关 提示 信息 
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echo "<script language='javascript>alert(' 您 输入 的 管理 员 名 称 错 误 ， 请 重新 输入 ! 
Dshistory.back();</script>"; 
exit; 
} 
else{ // 如 果 管理 员 名 称 或 密码 正确 ， 则 弹出 相关 提示 信息 
echo "<script>alert(' 管 理 员 登 录 成 功 !);window.location="index.php';</script>"; 
$_SESSION[admin_name]=$info[name]; // 将 管理 员 名 称 存 到 $_SESSION[admin_name] 变 量 中 


$_SESSION[pwd]=$infofpwd]; // 将 管理 员 密 码 存 到 $_SESSION[pwd] 变 量 中 
} 
| 
@ S$obj=new chkinput(trim($name),trim($pwd)); // 创 建 对 象 
目 Sobj->checkinputO; /调用 类 
?> 
< 人 代码 贴 十 


@ class: 创建 一 个 PHP 类 时 ， 必 须 使 用 关键 字 class 进行 声明 ， 该 关键 字 后 紧 跟 类 的 名 称 ， 之 后 用 大 括号 将 类 体 
进行 封装 。 

@ new: PHP 中 应 用 new 关键 字 创 建 对 象 。 该 模块 创建 了 一 个 名 为 chkinput 的 验证 管理 员 类 。 

@ $obj->checkinput();; 通过 $obj 对 象 调用 checkinput 类 中 的 属性 和 方法 ， 即 管理 员 名 称 和 密码 。 


7.6.4 查看 管理 员 的 实现 过 程 


国 ”查看 管理 员 使 用 的 数据 表 : tb_ manager、tb_purview 

管理 员 登 录 后 ， 选 择 “ 系 统 设置 ”/“ 管 理 员 设置 ”菜单 项 ， 进 入 到 查看 管理 员 列 表 页 面 。 在 该 页 
面 中 ， 将 以 表格 的 形式 显示 全 部 管理 员 及 其 权限 信息 ， 并 提供 添加 管理 员 信息 、 删 除 管理 员 信 息 和 设 
置 管理 员 权 限 的 超 链接 。 查 看 管理 员 列表 页 面 的 运行 结果 如 图 7.19 所 示 。 


二 点 图 必 亿 管理 系统 


MANAGE SYSTEM = zp 
当前 登录 的 用 户 : Tsoft 
首页 。 系统 设置 。 读者 管理 。 图 书 档案 管理 。 图 书 借 还 。。 系统 查询 。 更改 口令 ”注销 


当前 位 置 : 系统 设置 > 管理 员 设置 


添加 管理 员 信 息 
管理 员 名 称 系统 设置 读者 管理 。 图 书 档案 管理 。 图 书 异 还 ”系统 查询 ”权限 设置 ”操作 
Tsoft [3 本 属 反 本 权限 设置 。 删除 
admin 区 图 区 图 La 权限 设置 删除 
图 书迷 辆 局 所 反 本 权限 设置 。 册 除 


CopyRi aht @2007 www.mrbeed com 吉林 **## 师 范 大 学 图 书馆 
本 站 请 使 用 IE 6. 0 或 以 上 版 本 1024*+768 为 景 佳 显示 效果 


7.19 查看 管理 员 列 表 页 面 的 运行 结果 


SS 
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首先 使 用 左 外 联接 语句 〈left join…on) 从 数据 表 tb_manager 和 tb_purview 中 查询 出 符合 条 件 的 数 
据 ， 然 后 将 查询 结果 应 用 do…while 循环 语句 输出 到 浏览 器 。 关 键 代码 如 下 : 


例 程 06 ”代码 位 置 : 光盘 \TM\02\libraryimanager.php 


<?php 
include("conn/conn.php"); // 连 接 数据 库 文件 
©@ $sql=mysql query("select m.id,m.name,p.sysset,p.readerset,p.bookset,p.borrowback,p.sysquery from tb manager as m 
left join (select * from tb_purview) as p on m.id=p.id"); 
$info=mysql_fetch_array($sql); /检索 数据 信息 
dof /应 用 do…while 循 环 语句 输出 查询 结果 
> 
A 闵 率 玉米 六 六 六 率 闵 来 六 六 水 冰冰 水 闵 闵 闵 米 米 闵 洲 率 闵 率 六 ## 站 站 输出 符合 查询 条 件 的 记录 相机 下 机 中 机 机 机 中 机 本 机 机 宙 束 机 来 可 事 可 束 可 事 事 可 可 事 机 事 冰 机 */ 
<tr> 
<td style="padding: 5px;"><?php echo Sinfo[name];?></td> 
四 <td align="center"><input name="checkbox" type="checkbox" class="noborder" value="checkbox" 
disabled="disabled" <?php if(Sinfolsysset]==1){echo ("checked");}?>></td> 
<td align="center"><input name="checkbox" type="checkbox" class="noborder" value="checkbox" 
disabled="disabled" <?php if(Sinfo[readerset]==1){echo("checked");}?>></td> 
<td align="center"><input name="checkbox" type="checkbox" class="noborder" value="checkbox" disabled <?php 
if($info[bookset]==1){echo("checked");}?>></td> 
<td align="center"><input name="checkbox" type="checkbox" class="noborder" value="checkbox" disabled <?php 
if($info[borrowback]==1){echo("checked");}?>></td> 
<td align="center"><input name="checkbox" type="checkbox" class="noborder" value="checkbox" disabled <?php 
if(Sinfo[sysquery]==1){echo("checked");}?>></td> 
<td align="center"><a href="#" onClick="window.open('manager modify.php?id=<?php echo 
$info[id]; ?>"",width=292,height=175")"> 权 限 设 置 </a></td> 
<td align="center"><a href="manager_del.php?id=<?php echo $info[id];?>"> 删 除 </a></td> 
<?php 
}while(Sinfo=mysql_fetch_array(SsqD); /do…while 循 环 语句 结束 
> 


Ah 代码 贴 二 
@ leftjoin…on: 应 用 左 外 联接 将 两 个 表 或 多 个 表 连 接 起 来 ， 返 回 部 分 或 全 部 匹配 行 ， 详 解 参见 7.10.2 节 。 
@ <?php if($info[sysset]==1){echo ("checked");}?>: 如 果 系统 设置 字段 的 值 为 1， 则 复 选 框 处 于 选中 状态 。 


7.6.5 添加 管理 员 的 实现 过 程 
国 ”添加 管理 员 使 用 的 数据 表 : tb_manager 
管理 员 登 录 后 ， 选 择 “ 系 统 设置 ”/“ 管 理 员 设置 ”菜单 项 ， 进 入 到 查看 管理 员 列 表 页 面 ， 在 该 页 


面 中 单 击 “ 添 加 管理 信息 ” 超 链 接 ， 打 开 添 加 管理 员 信息 页 面 。 添 加 管理 员 信息 页 面 的 运行 结果 如 
图 7.20 所 示 。 


本 
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保存 关闭 


图 720 添加 管理 员 页 面 的 运行 结果 
全 注意 : 新 添加 的 管理 员 信息 没有 权限 ， 必 须 通过 设置 管理 员 权 限 为 其 指定 可 操作 的 功能 模块。 
在 查看 管理 员 列 表 页 面 ， 单 击 “ 添 加 管理 信息 ” 超 链 接 文字 的 HTML 代码 如 下 : 
例 程 07 ”代码 位 置 ， 光盘 \TM\02\library\manager.php 
<a href="#" onClick="window.open('manager_add.php',","width=292,height=175')"> 添 加 管理 员 信 息 </a> 


添加 管理 员 页 面 主 要 用 于 收集 输入 的 管理 员 信 息 及 通过 自 定义 的 JavaScript 函数 验证 输入 信息 是 
和 否 合法 。 该 页 面 中 所 涉及 到 的 表单 元 素 如 表 7.2 所 示 。 


表 7.2 添加 管理 员 页 面 所 涉及 的 表单 元 素 


Submit2 


在 添加 管理 员 页 面 中 ， 输 入 合法 的 管理 员 名 称 及 密码 后 ， 单 击 “保存 ”按钮 ， 提 交 表 单 信息 到 数 
据 处 理 页 ， 将 添加 的 管理 员 信 息 保 存 到 数据 表 中 。 如 果 添 加 成 功 ， 弹 出 成 功 的 提示 信息 ; 否则 ， 弹 出 
错误 提示 。 代 码 如 下 : 

例 程 08 ”代码 位 置 ， 光盘 \TM\02\library\manager_ok.php 


<2?php 

include("conn/conn.php"); // 连 接 数 据 库 文件 

if($_POST[submit]!=""){ // 如 果 单 击 了 “保存 ”按钮 ， 则 执行 下 面 的 操作 
$name=$_POST[name]; // 获 取 管 理 员 名 称 

Spwd=$_POST[pwd]; // 获 取 管 理 员 密 码 

$sql=mysql_ query("insert into tb_manager (name,pwd) values('$name’,$pwd')"); 

if($sql==true) { // 向 数据 表 中 添加 管理 员 信 息 成 功 ， 则 给 出 提示 信息 
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echo "<scriptlanguage=javascript>alert(' 管 理 员 添 加 成 功 ! ");window.close();window.opener.location.reload();</script>"; 


else{ 


} 
} 


?> 


// 向 数据 表 中 添加 管理 员 信息 失败 ， 则 给 出 提示 信息 
echo "<script language=javascript>alert(' 管 理 员 添加 失败 ! ");window.close();window.opener.location.reload();</script>"; 


发 、 技 巧 : 在 添加 管理 员 处 理 页 中 应 用 window.opener.location reload(); 语 揣 刷新 父 窗口 中 的 信息 。 


7.6.6 设置 管理 员 权限 的 实现 过 程 


国 ”设置 管理 员 权限 使 用 的 数据 表 : tb_ manager、tb_purview 
在 查看 管理 员 列 表 页 面 单 击 指定 管理 员 后 面 的 “权限 设置 ” 超 链接 ， 即 可 进入 到 “权限 设置 ”页 
面 ， 设 置 该 管理 员 的 操作 权限 。 权 限 设 置 页 面 的 运行 结果 如 图 7.21 所 示 。 


图 书 爱 好 者 
厂 系统 设置 ”三 读者 管理 


拥有 的 权限 : [图 书 管理 ”[Y 图 书 借 还 
[系统 查询 


Ea 


图 7.21 权限 设置 页 面 的 运行 结果 


权限 设置 页 面 中 所 涉及 到 的 表单 元 素 如 表 7.3 所 示 。 


表 7.3 ”权限 设置 页 面 所 涉及 的 表单 元 素 


名 称 元 素 类 型 重要 属性 含 义 
forml form method="post" action="manager_ modifyok.php” 表单 

id hidden value="<?php echo S$info[id];?>" 管理 员 编 号 
name text value= "<?php echo Sinfo[name]:?>" 管理 员 名 称 
Sysset checkbox <?php if($info[sysset]==1){ echo("checked");1?> 系统 设置 
readerset checkbox <?php if($info[readerset]—1){ echo("checked");}?> 读者 管理 
bookset checkbox <?php if($info[bookset]—1) {echo("checked");}?> 图 书 管理 
borrowback checkbox <?php if($info[borowback]==1){echo("checked"):}?> 图 书 借 还 
sysquei checkbox <?php if($info[sysquery]—1) {echo("checked");}?> 系统 查询 
submit submit class="btn_grey” “保存 ”按钮 
Submit2 button value=" 关 闭 " onClick="window.close();" “关闭 ”按钮 
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在 查看 管理 员 列 表 页 面 中 ， 添 加 “权限 设置 ” 列 ， 并 在 该 列 中 添加 以 下 用 于 打开 “权限 设置 ”页 
面 的 超 链接 代码 。 

例 程 09 ”代码 位 置 : 光盘 \TM\WO2NWlibrarymanagerphp 

<a href="#" onClick="window.open('manager_modify.php?id=<?php echo $info[id]; ?>',",width=292,height=175")"> 权 限 

设置 </a> 

从 上 面 的 URL 地 址 中 可 以 获取 设置 管理 员 权 限 页 所 涉及 到 的 id 号 ,将 id 号 提交 给 处 理 页 
manager_modifyok.php， 修 改 id 号 所 对 应 的 管理 员 信 息 。 具 体 代 码 如 下 : 

例 程 10 ”代码 位 置 ， 光盘 \TM\02\library\manager_modifyok.php 


<?php 
include("conn/conn.php"); // 连 接 数 据 库 文件 
if($_POST[submit]!=""){ // 如 果 提交 表单 ， 则 执行 以 下 操作 
$id=$_POST[id]; /获取 id 信息 
@ S$sysset=$_POSTIsysset]=""?0:1; // 应 用 三 目 运算 符 求 出 “系统 设置 ” 复 选 框 的 值 
Sreaderset=$_POST[readerset]==""?0:1; // 应 用 三 目 运 算 符 求 出 “读者 管理 ” 复 选 框 的 值 
Sbookset=$_POST[bookset]==""?0:1; // 应 用 三 目 运 算 符 求 出 “图 书 管理 ” 复 选 框 的 值 
Sborrowback=$_POST[borrowback]==""?0:1; /应 用 三 目 运算 符 求 出 “图 书 借 还 ” 复 选 框 的 值 
Ssysquery=$_POSTIsysquery]==""?0:1; // 应 用 三 目 运 算 符 求 出 “系统 查询 ” 复 选 框 的 值 
$query=mysql]_query("select * from tb_purview where id=$id"); 
S$info=mysql_fetch_array($query); /检索 权限 信息 表 中 是 否 存在 该 管理 员 
if($info—false){ /如 果 不 存在 ， 向 权限 表 中 添加 管理 员 权 限 信息 
四 mysql query("insert into tb purview(id,sysset,readerset,bookset,borrowback,sysquery) 
values($id,$sysset, $readerset,$bookset, $borrowback, $sysquery)"); 
} 
elsef /否则 ， 更 新 管理 员 的 权限 信息 


mysql query("update tb purview set 
sysset=$sysset,readerset=$readerset,bookset=$bookset,borrowback=$borrowback,sysquery=$sysquery “where id="$id"); 


} 

echo"<script language=javascript>alert(' 权 限 设置 修改 成 功 ! ');window.close();window.opener.location.reload();</script>"; 
// 更 新 成 功 ， 弹 出 提示 信息 ， 并 更 新 父 窗口 

b 


> 
Ah 代码 贴 十 
@ $_POST[sysset]==""?0:1;: 应 用 三 目 运 算 符 求 出 “系统 设置 ” 复 选 框 的 值 ， 如 果 等 于 空 ， 值 为 0， 否 则 值 为 1。 
四 insert…into: 向 权限 信息 表 中 添加 一 行 数据 信息 ，insert…into 语句 只 适用 于 对 单行 数据 的 插入 。 


7.6.7 ”删除 管理 员 的 实现 过 程 


国 ”删除 管理 员 使 用 的 数据 表 : tb_manager、tb_purview 

在 查看 管理 员 列 表 页 面 ， 单 击 指定 管理 员 信息 后 面 的 “删除 ” 超 链接 ， 该 管理 员 及 其 权限 信息 将 
被 删除 。 

在 查看 管理 员 列 表 页 面 中 添加 以 下 用 于 删除 管理 员 信息 的 超 链 接 代 码 。 


Sa 
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例 程 11 “代码 位 置 :光盘 \TM\07\library\manager.php 
<a href="manager_del.php?id=<?php echo $info[id];?>"> 删 除 </a> 
从 上 面 的 URL 地 址 中 ， 可 以 获取 删除 管理 员 所 涉及 到 的 id 号 , 将 id 号 提交 给 manager_del.php 处 
理 页 删除 id 号 所 对 应 的 管理 员 信息 。 有 具体 代码 如 下 : 
例 程 12 ”代码 位 置 ， 光盘 \TM\07\library\manager_del.php 


<2php 
include("conn/conn.php"); // 连 接 数 据 库 文件 
$id=$_GET[id]; // 获 取 管 理 员 的 id 号 


S$sql=mysql_query("delete from tb_manager where id=- Sid'"); /删除 管理 员 表 中 id 号 所 对 应 的 管理 员 信息 

$query=mysql_query("delete from tb_purview where id= Sid'"); /删除 权限 表 中 id 号 所 对 应 的 管理 员 权限 

if($sql==true and Squery 一 true ){ // 如 果 删 除 操作 成 功 ， 则 弹出 提示 信息 
echo "<script language=javascript>alert(' 管 理 员 删除 成 功 ! ");history.back();</script>"; 


} 

else{ // 如 果 删 除 操作 失败 ， 则 弹出 提示 信息 
echo "<script language=javascript>alert(' 管 理 员 删 除 失败 ! '");history.back();</script>"; 

) 

?> 


7.6.8 单元 测试 


在 开发 完 管理 员 模块 后 ， 对 该 模块 进行 单元 测试 。 当 管理 员 修改 操作 员 的 权限 时 ， 该 操作 员 的 权 
限 没有 改变 。 下 面 给 出 修改 权限 设置 处 理 页 的 源 代码 : 


<?php 


include("conn/conn.php"); // 连 接 数 据 库 文件 
if($_POST[submit]!=""){ // 如 果 提交 表单 ， 则 执行 以 下 操作 
$id=$_POSTI[id]; // 获 取 id 信 息 

$sysset=$_POSTIsysset]; 1/ 获取 “系统 设置 ” 复 选 框 的 值 
Sreaderset=$_POSTI[readerset]; /获取 “读者 管理 ” 复 选 框 的 值 
Sbookset=$_POST[bookset]; /获取 “图 书 管理 ” 复 选 框 的 值 
Sborrowback=$_POST[borrowback]; /获取 “图 书 借 还 ” 复 选 框 的 值 
S$sysquery=$_POSTIsysquery]; // 获 取 “ 系 统 查 询 ” 复 选 框 的 值 
$query=mysql query("select * from tb purview where id=$id"); 

$info=mysql_fetch_array($query); /检索 权限 信息 表 中 是 否 存在 该 管理 员 
if($info—false){ // 如 果 不 存在 ， 向 权限 表 中 添加 管理 员 权 限 信息 


mysql query("insert into tb purview(id,sysset,readerset,bookset,borrowback,sysquery) 
values($id,$sysset,$readerset,$bookset, $borrowback,$sysquery)"); 
上 
elsef /否则 ， 更 新 管理 员 的 权限 信息 
mysql query("update tb_purview set 
Sysset=$sysset,readerset=S$readerset,bookset=$bookset,borrowback=$borrowback,sysquery=$sysquery where id='$ 
} 


); 


echo"<scriptlanguage=javascript>alert( 权 限 设置 修改 成 功 ! ");window.close();window.opener.location.reload();</script>"; 


/更 新 成 功 ， 弹 出 提示 信息 ， 并 更 新 父 窗口 
“351。 g 


} 
> 
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为 了 找 出 错误 的 原因 ， 笔 者 应 用 echo0 语 句 对 $sysset 等 一 系列 传递 的 值 进行 输出 ， 输 出 的 结果 显 
示 $sysset 的 值 始终 等 于 0， 这 充分 说 明 在 修改 复 选 框 时 ， 没 有 获取 到 选中 复 选 框 的 值 。 

解决 该 问题 的 方法 对 提交 的 复 选 框 的 状态 进行 判断 ， 如 果 复 选 框 处 于 未 选中 状态 ， 则 值 为 0; 如 果 
复 选 框 处 于 选中 状态 ， 则 值 为 1。 这 样 就 可 以 获取 到 复 选 框 选 中 状态 的 值 了 。 

处 理 复 选 框 的 状态 有 两 种 方法 : 一 种 是 应 用 if 条 件 语句 对 逐个 值 进行 判断 ， 判 断 复 选 框 的 当前 状 
态 ， 并 赋予 其 值 〈 但 这 种 方法 过 繁琐 ) ; 另 一 种 是 应 用 三 目 运 算 符 ， 简 单 快捷 地 计算 复 选 框 的 值 ( 这 
种 方法 可 以 简化 代码 ， 本 模块 采用 该 方法 获取 复 选 框 的 值 〉。 

应 用 三 目 运 算 符 获取 复 选 框 的 值 的 代码 如 下 : 


Ssysset=$_POSTIsysset]==""?0:1; // 应 用 三 目 运算 符 求 出 “系统 设置 ” 复 选 框 的 值 
Sreaderset=$_POSTI[readerset]==""?0:1; // 应 用 三 目 运 算 符 求 出 “读者 管理 ” 复 选 框 的 值 
Sbookset=$_POST[bookset]==""?0:1; // 应 用 三 目 运 算 符 求 出 “图 书 管理 ” 复 选 框 的 值 
Sborrowback=$_POST[borrowback]==""?0:1; // 应 用 三 目 运算 符 求 出 “图 书 借 还 ” 复 选 框 的 值 
Ssysquery=$_POSTIsysquery]==""?0:1; // 应 用 三 目 运 算 符 求 出 “系统 查询 ” 复 选 框 的 值 


完整 的 权限 设置 处 理 页 的 代码 参见 例 程 10。 
7.7 ”图 书 档案 管理 模块 设计 


7.7.1 图 书 档案 管理 模块 概述 


图 书 档案 管理 模块 主要 包括 查看 图 书 列表 、 添 加 图 书信 息 、 修 改 图 书信 息 、 删 除 图 书信 息 和 查看 
图 书 详细 信息 等 5 个 功能 。 图 书 档案 模块 的 框架 如 图 7.22 所 示 。 


CD 


图 书信 息 列 表 


| [者 四 # 雪 | | [sm 信和 | | [| 修改 图 书信 息 


| 开除 图 书信 息 | | | 查看 图 书 详细 信息 


图 7.22 图书 档案 模块 的 框架 图 


7.7.2 ”图书 档案 管理 模块 技术 分 析 
在 图 书 档案 管理 模块 中 ， 涉 及 到 的 数据 表 是 tb_bookinfo 〈 图 书信 息 表 ) 、tb_bookcase (书架 设置 


表 ) 、tb_booktype (图 书 类 型 表 ) 和 tb_publishing (出 版 社 信 息 表 ) ， 这 4 个 数据 表 间 通过 相应 的 字段 
进行 关联 ， 如 图 7.23 所 示 ， 通 过 以 上 4 个 表 可 以 获得 完整 的 图 书 档案 信息 。 
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tb_booktype 


tb_bookinfo 


id integer unsigened <pk> 


typename varchar (30) i integer (11) 《pk> 


days integer unsiened int 
varchar (T0) 


和 
ISBN var char (20) D 全 人 
pubname varchar (30) oat (8, 


Fk _booktype i integer unsiened 《fk3> 
var char (30) 


《fk2> 


integer unsiened 


integer unsiened 《fkl> 


Fk_bookcase EE 
tb_bookcase var char (30) 


tinyint (1) 


id integer unsigned 《pk> 
name varchar (30) 


图 7.23 图 书 档案 管理 模块 各 表 间 关系 图 


全 注 意 : 本 模块 主要 应 用 联接 语句 实现 多 表 查 询 ， 关 于 联接 语句 的 详细 讲解 参见 7.10 节 。 


7.7.3 查看 图 书信 息 列表 的 实现 过 


国 查看 图 书信 息 列表 使 用 的 数据 表 : 
管理 员 登 录 后 ， 选 择 “ 图 书 管理 ” 


面 中 将 显示 全 部 图 书信 息 列表 ， 同 时 提供 添加 图 书信 息 、 删 除 图 书信 息 、 
看 图 书信 息 列 表 页 面 的 运行 结果 如 图 7.24 所 示 。 


MANAGE SYSTEM 


伍 记 辕 思 馈 管 理 系统 


首页 。 系统 设置 。 读者 管理 。 图 书 档案 管理 。 图书 惜 还 


tb_bookinfo、tb_bookcase、tb_booktype、tb_publishing 
/“ 图 书 档案 管理 ”菜单 项 ， 进 入 到 查看 图 书 列表 页 面 ， 在 该 页 


修改 图 书信 息 的 超 链接 。 查 


当前 位 置 : 图 书 管理 > 图 书 档案 管理 


条 形 码 
123456789 


123454321 


987654321 


图 书 名 称 图 书 类 型 出 版 社 
PIHE 数 据 库 系统 开发 完全 手册 数据 库 技术 人 民 邮 电 出 版 社 


PIF 程序 开发 范例 宝典 宝典 系列 人 民 邮 电 出 版 社 
PE 函数 参考 大 全 信息 科学 技术 人 民 邮 电 出 版 社 


CopyRight @2007 www.mrbeccd. com 吉林 *#+# 师 范 大 学 图 书馆 
本 站 请 使 用 IE 6.0 或 以 上 版 本 1024*768 为 最 佳 显示 效果 


7.24 ”查看 图 书信 息 列表 的 运行 结果 


添加 图 书信 息 


修改 
修改 


册 除 
删除 


删除 
删除 
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打开 功能 导航 navigation.php 文件 ， 设 置 “图 书 档案 管理 ”菜单 项 的 超 链接 的 代码 如 下 : 

例 程 13 ”代码 位 置 : 光盘 \TM\02\library\navigation.php 

<a href="book.php" class="al"> 图 书 档案 管理 </a> 

首先 应 用 join…on 内 联接 语句 将 tb_bookinfo、tb_bookcase、tb_booktype 和 tb_publishing 4 个 数据 
表 连 接 起 来 检索 指定 条 件 的 图 书信 息 , 然后 应 用 do…while 循环 语句 输出 查询 结果 到 浏览 器 。 查看 图 书 
信息 页 面 的 代码 如 下 : 

例 程 14 ”代码 位 置 ， 光盘 \TM\07\library\book.php 

<2php 

include("conn/conn.php"); // 连 接 数 据 库 文件 

$query=mysql query("select book.barcode,book.id as bookid,book.bookname,bttypename,pb.pubname,bc.name from 


tb_bookinfo book join tb_booktype bt on book.typeid=bt.id join tb_publishing pb on book.ISBN=pb.ISBN join tb_bookcase bc 
on book.bookcase=bc.id"); 


$result=mysql_fetch_array($query); // 应 用 外 联接 检索 图 书信 息 
2> 
// 省 略图 书信 息 标题 HTML 标 记 部 分 
<2?php 
dof // 应 用 do…while 循 环 语句 输出 查询 结果 
人 > 
<tr> 


<td style="padding: 5px;">&nbsp;<?php echo $result[barcode];?></td> 

<td style="padding: Spx;"><a href="book_look.php?id=<?php echo $result[bookid];?>"><?php echo 
$result[bookname];?></a></td> 

<td style="padding: 5px;">&nbsp;<?php echo $result[typename];?></td> 

<td style="padding: 5px;">&nbsp;<?php echo $result[pubname];?></td> 

<td style="padding: 5px;">&nbsp;<?php echo $result[name];?></td> 

<td align="center"><a href="book_Modify.php?id=<?php echo $result[bookid];?>"> 修 改 </a></td> 

<td align="center"><a href="book_del.php?id=<?php echo $result[bookid];?>"> 删 除 </a></td> 

</tr> 


<? 


whlletSresult=mysql feteh,array(Sauer)) //do…while 循 环 语句 结束 
全 注意 : 关于 join.…on 内 联接 语句 的 使 用 方法 参见 7.10.1 节 。 
7.7.4 添加 图 书信 息 的 实现 过 程 
国 ”添加 图 书信 息 使 用 的 数据 表 : tb_bookinfo、tb_bookcase、tb_booktype、tb_publishing 
管理 员 登 录 系 统 后 ， 在 导航 栏 中 单 击 “ 图 书 档案 管理 ” 超 链 接 ， 进 入 到 查看 图 书 列表 页 面 。 在 该 


页 面 中 单 击 “ 添 加 图 书信 息 ” 超 链接 ， 进 入 到 添加 图 书信 息 页 面 。 添 加 图 书信 息 页 面 的 运行 结果 如 
图 7.25 所 示 。 
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二 和 园 加 馆 管理 系统 


当前 位 置 : 图 书 档案 管理 


MANAGE SYSTEM 


首页 


系统 设置 


读者 管理 。 图 书 档案 管理 。 图 书 借 还 。 ”系统 查询 


条 加 图 书信 息 


条 形 码 : 865888999 

国名 称 : rE : 
图 书 类 型 : 本 不”“ 司 

作 者 : 最 天 思 、 潘 斋 华 、 刘 中 华 

译 者 : Prsoft 

出 版 社 : [导电 出 版 社 司 

价 格 : 9 FE) 

页 码 : Ey 

书 架 : [ES | 


当前 登录 的 用 户 : Tsoft 
更 改口 令 


CopyRight 加 2007 www. mrbecd com 吉林 +++ 师 范 大 学 图 书馆 
本 站 请 使 用 IE 6. 0 或 以 上 版 本 1024*#768 为 最 佳 显 示 效果 


注销 


图 7.25 添加 图 书信 息 页 面 的 运行 结果 


在 查看 图 书 列表 页 面 中 ， 设 置 “ 添 加 图 书信 息 ” 超 链接 的 代码 如 下 : 
例 程 15 ”代码 位 置 ; 光盘 \TM\07\library\book.php 
<a href="book_add.php"> 添 加 图 书信 息 </a> 


添加 图 书信 息 页 面 主要 用 于 收集 输入 的 图 书信 息 以 及 通过 自 定义 的 JavaScript 函数 验证 输入 信息 
是 否 合法 。 该 页 面 中 所 涉 及 到 的 重要 表单 元 素 如 表 7.4 所 示 。 


名 称 


表 7.4 添加 图 书信 息 页 面 所 涉及 的 重要 表单 元 素 
重要 属性 


forml 


typeld 


method="post" action="book_ok.php” 

<?php include("Conn/conn.php"); 
S$sql=mysql_query("select * from tb_booktype"); 
Sinfo=mysql_fetch_array($sq]); 
dof 

> 

<option value="<?php echo $info[id];?>"> 

<2?php echo $info[typename];?></option> 

<7| while(S$info=mysql fetch array($sql));?> 


图 书 类 型 
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续 表 
名 称 元 素 类 型 重要 属性 含义 
<?php 
$sql2=mysql_ query("select * from tb_publishing"); 
$info2=mysql_fetch_array($sql2); 
isbn Select > Wak 出 版 社 
<option value="<?php echo $info2[ISBN];?>"> 
<?php echo $info2[pubname];?></option> 
<2?php }while(Sinfo2=mysql_fetch_array($sql2)):?> 
<2php 
$sql3=mysql_ query("select * from tb_bookcase"); 
S$info3=mysql_fetch_array($sql3); 
bookcaseid select es i 书架 名 称 
<option value="<?php echo $info3[id];?>"> 
<?php echo $info3[name];?></option> 
?php }while($info3=mysql_fetch_array($sql3)):?> 
operator hidden ?php echo $info3[name]:2>” 操作 员 
Submit submit onClick="return check(form1)" “保存 ”按钮 
Submit2 button onClick="history.back():;" “返回 ”按钮 
由 于 添加 图 书信 息 的 方法 同 添加 管理 员 信 息 的 方法 类 似 ， 所 以 此 处 只 给 出 向 图 书信 息 表 中 插入 数 


据 的 SQL 语句 ， 详 细 代 码 参 见 光 盘 。 向 图 书信 息 表 中 插入 数据 的 SQL 语句 如 下 : 
例 程 16 ”代码 位 置 ， 光盘 \TM\07\library\book_ok.php 


mysql query("insert into 
tb_bookinfo(barcode,bookName,typeid,author,translator.ISBN,price,page,bookcase,inTime,operator )values('$barcode',$bookN 
ame',' $typeid','$author','$translator','$isbn','$price','$page','$bookcaseid','$inTime','$operator’)"); 


7.7.5 修改 图 书信 息 的 实现 过 程 


国 ”修改 图 书信 息 使 用 的 数据 表 : tb_bookinfo、tb_bookcase、tb_booktype、tb_publishing 

管理 员 登 录 系 统 后 ， 在 导航 栏 中 单 击 “ 图 书 档案 管理 ” 超 链 接 ， 进 入 到 查看 图 书 列 表 页 面 。 单 击 
想 要 修改 的 图 书信 息 后 面 的 “修改 ” 超 链接 ， 进 入 到 “修改 图 书信 息 ” 页 面 。 修 改 图 书信 息 页 面 的 运 
行 结果 如 图 7.26 所 示 。 
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四 = 内 


当前 位 置 : 图 书 档案 管理 > 修改 图 书信 息 
条 形 码 : 
图 书 名 称 : 
图 书 类 型 : 


作 者 : 
译 者 : 


出 版 社 : 


价 格 : 


页 码 : 


书 架 : 


当前 登录 的 用 Pi Tsoft 
首页 。 系统 设置 。 读者 管理 。 图 书 档案 管理 。 图书 异 还 。 系统 查询 。 更 疏 口令 。 注销 
EE 手册 * 
数据 库 技术 S| 


邹 天 思 、 潘 妆 华 、 刘 中 华 


nrsoft 


人 和民 于 电 出 版 社 避 


| 人民 邮电 出 版 社 
Ee 


| 
保存 | 返回 
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7.26 ”修改 图 书信 息 页 面 的 运行 结果 


在 图 书信 息 列表 页 面 中 ， 添 加 “修改 ” 超 链 接 的 代码 如 下 : 
例 程 17 ”代码 位 置 ， 光盘 \TM\07\library\book.php 
<a href="book_Modify.php?id=<?php echo $result[bookid];?>"> 修 改 </a> 
在 修改 图 书信 息 页 面 中 修改 图 书信 息 后 ， 单 击 “ 保 存 ” 按 钮 ， 提 交 表 单 信息 到 数据 处 理 页 
book_Modify_ok.php， 应 用 UPDATE 语句 将 修改 的 图 书信 息 保存 到 数据 表 tb_bookinfo 中 ， 并 弹出 “图 
书信 息 修改 成 功 ! ”提示 信息 ， 将 页 面 重 定向 到 修改 图 书信 息 页 。 数 据 处 理 页 的 代码 如 下 : 
例 程 18 ”代码 位 置 ， 光盘 \TM\07\library\book_Modify_ok.php 


<?php 

session_start(); // 初 始 化 session 变 量 
include("conn/conn.php"); // 连 接 数 据 库 文件 
$bid=$_POST[bid]; // 获 取 图 书 id 号 
S$operator=$_SESSION[admin_name]; // 获 取 管 理 员 名 称 
S$barcode=$_POST[barcode]; /获取 图 书 条 形 码 
$bookName=$_POST[book Name]; // 获 取 图 书 名 称 
Stypeid=$_POST[typeld]; /获取 图 书 类 型 id 号 
S$author=$_POST[author]; /获取 图 书 作者 
S$translator=$_POST[translator]; /获取 图 书 译 者 
Sisbn=$_POST[isbn]; /获取 出 版 社 ISBN 
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S$price=$_POST[price]; /获取 图 书 单价 
Spage=$_POST[page]; // 获 取 图 书页 码 
S$bookcase=$_POST[bookcaseid]:; /获取 图 书 书架 id 号 
SinTime=date("Y-m-d"); /设置 图 书 更 新 日 期 为 当前 日 期 


$query=mysql_query("update tb_bookinfo set barcode= Sbarcode', bookName='$bookName' , typeid='$typeid', 
author='$author, translator='$translator, ISBN='$isbn' , price='$price' , page='$page' , bookcase='$bookcaseid', 
inTime='$inTime', operator='$operator where id=$bid"); /更 新 数据 表 

echo "<script language='javascript >alert(' 图 书信 息 修改 成 功 !""):history.back();</script>"; 

> 


7.7.6 删除 图 书信 息 的 实现 过 程 


国 ”删除 图 书信 息 使 用 的 数据 表 : tb_bookinfo 

在 查看 图 书 列表 页 面 中 ， 设 置 “删除” 超 链接 的 代码 如 下 : 

例 程 19 ”代码 位 置 ， 光盘 \TM\07\library\book.php 

<a href="book_del.php?id=<?php echo $result[bookid];?>"> 删 除 </a> 

单 击 想 要 删除 的 图 书信 息 后 面 的 “删除 ” 超 链接 ， 提 交 表 单 信息 到 数据 处 理 页 book_del.php， 应 用 
DELETE 语句 将 指定 的 图 书信 息 从 数据 表 tb_bookinfo 中 删除 ， 如 果 删 除 操作 执行 成 功 ， 则 弹出 “图 书 
信息 删除 成 功 ! ”提示 信息 ， 并 将 页 面 重 定向 到 图 书信 息 列表 页 面 。 数 据 处 理 页 的 代码 如 下 : 

例 程 20 ”代码 位 置 ， 光盘 \TM\07\library\book_del.php 


<?php 

include("conn/conn.php"); // 连 接 数 据 库 文件 
$info_del=mysql_query("delete from tb_bookinfo where id=$_GET[id]"); // 删 除 指定 的 图 书信 息 
if($info_deD){ // 如 果 信 息 删 除 成 功 ， 则 弹出 提示 


echo "<script language='javascript >alert(' 图 书信 息 删 除 成 功 !");history.back();</script> "; 


> 


7.8 图 书 借 还 模块 设计 


7.8.1 图 书 借 还 模块 概述 


图 书 借 还 模块 主要 包括 图 书 借阅 、 图 书 续 借 、 图 书 归 还 、 图 书 档案 查询 、 图 书 借阅 查询 、 借 阅 到 
期 提醒 等 6 个 功能 。 在 图 书 借阅 模块 中 的 用 户 只 有 一 种 身份 ， 那 就 是 操作 员 ， 通 过 该 身份 可 以 进行 图 
书 借 还 等 相关 操作 。 图 书 借 还 模块 的 用 例 图 如 图 7.27 所 示 。 
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(Eeesa) 7 图 书 借阅 
CEemmn) (Hi) 一 一 (Eees ) Casas ) 
借阅 到 其 提要 这 


图 7.27 图 书 借 还 模块 的 用 例 图 
7.8.2 图 书 借 还 模块 技术 分 析 


在 图 书 借 还 模块 中 涉及 到 的 数据 表 是 tb_borrow〔 图 书 借阅 信息 表 ) 、tb_bookinfo (图 书信 息 表 ) 
和 tb_reader 读者 信息 表 ) ， 这 3 个 数据 表 间 通过 相应 的 字段 进行 关联 ， 如 图 7.28 所 示 。 


th reader 
thoskings ia intoger wnsigned pk》 
i ierlD GS nane varchar (20) 
arcode int sex varchar (4) 
booknane varchar (70) barcode varchar (30) 
typeid integer unsiened FR_reader| vocation 。 varchar (50) 
author var char (30) IFK_book tb_borrow birthday date 
translator varchar (30) - - - Type varehar (10) 
id integer unsigned 《pk> aba 
区 人 readerid 。 integer unsigned 。 《El2> 下 
Te ad bookid integer (10) 《fkl> tal varehar C0) 
bookease integer unsigned Derr ng ost es 0 
iarime ake en backTine date createDate date 
operator varchar (30) Dartoe, “verebien 0) | 
renar ex 
del tinyint (1) ifback _ tisyint ) 上 


图 7.28 图 书 借 还 管理 模块 各 表 间 关系 图 
全 注意 : 本 模块 主要 应 用 联接 语句 实现 多 表 查 询 ， 关 于 联接 语句 的 详细 讲解 参见 7.10 节 。 


7.8.3 图 书 借阅 的 实现 过 程 


国 ”图书 借 阅 使 用 的 数据 表 : tb_borrow、tb_bookinfo、tb_reader 

管理 员 登 录 后 ， 选 择 “ 图 书 借 还 ”/“ 图 书 借阅 ”菜单 项 ， 进 入 到 图 书 借阅 页 面 ， 在 该 页 面 中 的 “ 读 
者 条 形 码 ”文本 框 中 输入 读者 的 条 形 码 (如 123456789) 后 ， 单 击 “ 确 定 ”按钮 ， 系 统 会 自动 检索 出 该 
读者 的 基本 信息 和 未 归还 的 借阅 图 书信 息 。 如 果 检 索 到 对 应 的 读者 信息 ， 将 其 显示 在 页 面 中 ， 此 时 输 
入 图 书 的 条 形 码 或 图 书 名 称 后 ， 单 击 “ 确 定 ”按钮 ， 借 阅 指定 的 图 书 ， 和 运行 结果 如 图 7.29 所 示 。 
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汪 用 可 管 入 
BO KAO LiB Y MANAGE SYSTEM i 
系统 查询 。 更 改口 令 注销 


首页 。 系统 设置 。 读者 管理 。 图 书 档案 管理 。 图 书 异 还 


当前 位 置 ; 图 书 借 还 》 图 书 借阅 


卜 四 囊 借阅 

读者 验证 读者 条 形 码 : [23456755 | 确定 | 

姓 名 :区 而 | 性 别 : 区 读者 类 型 公务员 

证 件 类 型 : 府 份 证 证 件 号 码 : [220104123314#* 可 借 数 量 : 5 | 册 
添加 的 傅 据 : ”图书 条 形 码 。 “(图 书 名 称 ”证 函 涛 本 圭 大 全 ] 确定 || 完成 漠 阅 | 

图 书 名 称 借阅 时 间 应 还 时 间 出 版 社 书架 定价 挝 ) 
PHP 函数 参考 大 全 2007-12-06 2008-01-05 人 民 邮 电 出 版 社 PHP 书架 99.00 
PHE 数 据 库 系统 开发 完全 手册 2007-12-06 2008-01-05 人 民 邮 电 出 版 社 PHF 书架 85.00 
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图 7.29 图 书 借阅 页 面 的 运行 结果 
[0] 说 明 ， 当 读者 借阅 图 书 完毕 后 ， 操 作 员 通过 单 击 “ 完 成 借阅 ”按钮 ， 将 重新 载 入 图 书 借阅 页 面 ， 
当前 页 处 于 空 信息 状态 ， 从 而 方便 操作 员 进行 下 一 个 读者 借阅 图 书 操作 。 
图 书 借阅 页 面 总 体 上 可 以 分 为 两 个 部 分 : 一 部 分 用 于 查询 并 显示 读者 信息 ; 另 一 部 分 用 于 显示 读 
者 的 借阅 信息 和 添加 读者 借阅 信息 。 图 书 借阅 页 面 在 Dreamweaver 中 的 设计 效果 如 图 7.30 所 示 。 


证 件 类 型 ; 


图 7.30 图 书 借阅 页 面 的 设计 效果 

在 进行 图 书 借阅 时 ， 系 统 要 求 每 个 读者 只 能 同时 借阅 一 定数 量 的 图 书 ， 并 且 该 数量 由 读者 类 型 表 
tb_readerType 中 的 可 借 数 量 number 决定 ， 所 以 笔者 编写 了 自 定 义 的 checkbookO) 函 数 ， 用 于 判断 当前 
选择 的 读者 是 否 还 可 以 借阅 新 的 图 书 ， 同 时 该 函数 还 具有 判断 输入 读者 条 形 码 或 图 书 名 称 文本 框 是 否 


Sm 
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为 空 的 功能 。 代 码 如 下 : 
例 程 21 ”代码 位 置 ， 光盘 \TM\02\bookBorrow.php 


<script language="javascript"> 


function checkbook(form){ // 自 定义 一 个 JavaScript 函 数 checkbook() 
ifform .barcode.value 一 ""){ /如 果 读 者 条 形 码 为 空 
alert(" 请 输入 读者 条 形 码 1");form.barcode.focus():return; // 弹 出 提示 ， 焦 点 返回 到 条 形 码 文本 框 
} 
if(form.inputkey.value=—=""){ // 如 果 图 书 查询 文本 框 的 值 为 空 
alert(" 请 输入 查询 关键 字 !");form.inputkey.focus();return; // 弹 出 提示 ， 焦 点 返回 到 图 书 查 询 文本 框 
} 
if(form.number.value-form.borowNumber.value<=0){ /如 果 图 书 的 借阅 数量 超过 了 可 借 数量 
alert(" 您 不 能 再 借阅 其 他 图 书 了 !");return; // 弹 出 提示 信息 
} 
form.submit(); // 提 交 表 单 
</script> 


技巧 : 在 JavaScript 中 比较 两 个 数值 型 文本 框 的 值 时 ， 不 使 用 运算 符 “==”， 而 是 将 这 两 个 值 相 
减 ， 再 判断 其 结果 。 

检索 读者 的 基本 信息 和 未 归还 的 借阅 图 书信 息 的 SQL 语句 如 下 : 

例 程 22 ”代码 位 置 ， 光盘 \TM\07\library\bookborrow.php 

$sql=mysql_query("select r.*,t.name as typename,t.number from tb_reader r left join tb_readerType t on rtypeid=tid 
Where rbarcode='$barcode'"); 

$info=mysql_fetch_array($sql); /检索 读者 信息 

获取 读者 借阅 信息 的 SQL 语句 如 下 : 

例 程 23 ”代码 位 置 ， 光 盘 \TM\07\library\bookborrow.php 


$sqll=mysql_query("select r.*,borr.borrowTime,borr.backTime,book.bookname,book.price,pub.pubname,bc.name as 
bookcase from tb borrow as borr join tb bookinfo as book on book.id=borr.bookid join tb publishing as pub on 
book.ISBN=pub.ISBN join tb_bookcase as bc on book.bookcase=bc.id join tb_reader as r on borr.readerid=r.id where 
borrreaderid='$readerid' and borr.ifback=0"); 
Sinfol =mysql_fetch_array($sql1); /检索 读者 的 借阅 信息 
$borrowNumber=mysql_num_rows($sql1); /获取 结果 集中 行 的 数目 


在 “图 书 条 形 码 ”/“ 图 书 名 称 ” 文 本 框 中 输入 图 书 条 形 码 或 图 书 名 称 后 ， 单 击 “ 确 定 ” 按 钮 ， 检 
索 图 书信 息 是 否 存在 ， 如 果 不 存在 ， 则 向 图 书 借阅 信息 表 中 添加 该 读者 的 图 书 的 借阅 记录 ， 完 成 图 书 
借阅 操作 ， 和 否则 ， 弹 出 该 书 不 能 被 同一 读者 重复 借阅 的 提示 信息 。 图 书 借阅 的 具体 代码 如 下 : 

例 程 24 ”代码 位 置 : 光盘 \TM\07\library\bookBorrow.php 


<?php 
if($_POST[inputkey]!=""){ /如 果 “ 图 书 条 形 码 ”/“ 图 书 名 称 ” 后 的 文本 框 不 为 空 
$f=$_POSTI[f]; /获取 用 户 选择 的 条 件 值 
@ $inputkey=trim($ POST[inputkey]); /获取 用 户 输入 的 查询 关键 字 
Sbarcode=$_POST[barcode]; // 获 取 读 者 的 条 形 码 
Sreaderid=$_POST[readerid]; /获取 读者 id 号 


@ $borowTime=date('Y-m-d"); // 图 书 的 借阅 时 间 为 系统 当前 时 间 
361 乡 
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目 。 $backTime=date("Y-m-d",(time0+3600*24*30)); /归还 图 书 日 期 为 当前 期 日 期 +30 天 期 限 
$query=mysql query("select * from tb bookinfo where $ 全 'Sinputkey'"): 


Sresult=mysql_fetch_array($query); // 检 索 图 书信 息 是 否 存在 
if($result==false){ // 如 果 读 者 借阅 的 图 书 不 存在 ， 那 么 弹出 提示 信息 


echo "<scriptlanguage='javascript>alert(' 该 图 书 不 存在 ! 
");window.location.href='bookBorrow.php?barcode=$barcode'; </script>"; 
} 


elsef /检索 该 读者 所 借阅 的 图 书 是 否 与 再 借 图 书 重复 
$query1=mysql_query("select r.*,borr.borrow Time,borr.backTime,book.bookname,book.price,pub.pubname,bc.name 
as bookcase from tb borrow as borr join tb reader as r on borrreaderid=r.id join tb bookinfo as book on book.id=borr.bookid 
join tb publishing as pub on book.ISBN=pub.ISBN join tb bookcase as bc on book.bookcase=bc.id where 
borr.bookid=S$result[id] and borr.readerid=$readerid and ifback=0"); 
$resultl=mysql_fetch_array($query1); 
if($result1=—true){ // 如 果 所 借 图 书 已 被 该 读者 借阅 ， 那 么 提示 不 能 重复 借阅 
echo "<script language-javascript>alert( 该 图 书 已 经 借阅 ! 
");window.location.href='"book Borrow.php?barcode=$barcode';</script>"; 
b 
else{ // 否 则 ， 完 成 图 书 借阅 操作 ， 并 弹出 借阅 成 功 提示 信息 
$bookid=$result[id]; // 将 读者 id 号 赋 给 一 变量 
mysql_query("insert into 
tb borrow(readerid,bookid,borrowTime,back Time,operator,ifback)values('$readerid''$bookid','$borrowTime',$backTime','$ S 
ESSION[admin_name]',0)"); // 向 借阅 信息 表 中 添加 一 条 借阅 信息 
echo "<script language='javascript>alert(' 图 书 借阅 操作 成 功 ! ' 
);window.location.href='bookBorrow.php?barcode=$barcode';</script>"; 
} 


} 
} 


> 
< 代码 贴 二 

@trim(): 删除 字符 串 中 首尾 的 空白 或 者 其 他 字符 ， 以 达到 精确 查询 。 

@ date('Y-m-d): 获取 系统 的 当前 日 期 为 图 书 借阅 的 日 期 ， 并 格式 化 日 期 格式 。 

@ date("Y-m-d",(time(0+3600*24*30)): 归还 图 书 日 期 = 当前 期 日 期 130 天 期 限 。 当 前 日 期 时 间 稚 应 用 time() 函 数 获 
取 ，30 天 期 限 的 时 间 戳 等 于 3600 秒 x24 小 时 x30 天 ， 并 通过 date() 函 数 格式 化 为 指定 日 期 格式 。 


7.8.4 图 书 续 借 的 实现 过 程 


国 图书 续 借 使 用 的 数据 表 : tb_borrow、tb_bookinfo、tb_reader 

管理 员 登 录 后 ,选择 “图 书 借 还 ”/“ 图书 续 借 ” 菜单 项 ， 进 入 到 图 书 续 借 页 面 。 在 该 页 面 中 的 “ 读 
者 条 形 码 ”文本 框 中 输入 读者 的 条 形 码 (如 123456789) 后 ， 单 击 “ 确 定 ”按钮 ， 系 统 会 自动 检索 出 该 
读者 的 基本 信息 和 未 归还 的 借阅 图 书信 息 。 如 果 检 索 到 对 应 的 读者 信息 ， 则 将 其 显示 在 页 面 中 ， 此 时 
单 击 “ 续 借 ” 超 链接 , 即 可 续 借 指定 图 书 (即将 该 图 书 的 归还 时 间 加 上 该 书 的 可 借 天 数 30 天 计算 得 出 ) 。 
图 书 续 借 页 面 的 运行 结果 如 图 7.31 所 示 。 
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全 各 同志 亿 管 理 系 统 E 
当前 登录 的 用 户 : Tsoft 


首页 。 系统 设置 。 读者 管理 。 ”图书 档案 管理 。 图 书 借 还 。。 系统 查询 。 更 改口 令 。 注销 


当前 位 置 : 图 书 借 还 》 图 书 续 异 >>》 


由 图 韦 续 借 
读者 验证 姓 名 : 陈 丽 性 别 : 区 
读者 条 形 码 : 证 件 类 型 : 上 身份 证 证 件 号 码 : [22010412331#kx 
123456789 确定 | 读者 类 型 : | 公务 员 可 异 数 量 : 后 册 
图 书 名 称 借阅 时 间 应 还 时 间 出 版 社 书架 定价 抑 ) 完成 续 异 
PIPE 数据 库 系 统 开发 完全 手册 ”2007-12-06 2008-01-05 人 民 邮 电 出 版 社 FHF 书架 65.00 续 借 


CopyRi ght @2007 www.mrbccd. com 吉林 *++ 师 范 大 学 图 书馆 
本 站 请 使 用 IE 6. 0 或 以 上 版 本 1024*768 为 最 佳 显示 效果 


图 7.31 图 书 续 借 页 面 的 运行 结果 
[ 说 明 : 当 读者 续 借 完 图 书后 ， 操 作 员 通 过 单 击 “ 完 成 续 借 ” 按 钮 ， 将 重新 载 入 图 书 续 借 页 面 ， 当 
前 页 处 于 空 信息 状态 ， 从 而 方便 操作 员 进行 下 一 个 读者 续 借 图 书 操作 。 
图 书 续 借 页 面 的 设计 方法 同 图 书 借阅 类 似 ， 所 不 同 的 是 ， 在 图 书 续 借 页 面 中 没有 添加 借阅 图 书 的 
功能 ， 而 是 添加 了 “ 续 借 ” 超 链接 。 图 书 续 借 页 面 在 Dreamweaver 中 的 设计 效果 如 图 7.32 所 示 。 


六 ”名 : Ronin echo Finiotnme] 注 别 : Renhp echo Sinfolser]:T 


读者 类 型 : [pkp echo FinEoTtvpenw 。 河 异 数 量 : [pkp echo $nEo| 抽 


图 7.32 图 书 续 借 页 面 的 设计 效果 
单 击 “ 续 借 ” 超 链接 时 ， 还 需要 将 读者 条 形 码 、 借 阅 id 号 和 图 书 归 还 时 间 一 同 传递 到 图 书 续 借 的 
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处 理 页 borrow_oncemore.php 中 。 代 码 如 下 : 
例 程 25 ”代码 位 置 ， 光盘 \TM\07\library\bookRenew.php 
<a href="borrow_oncemore.php?barcode=<?php echo $info[barcode];?>&borrid=<?php echo 
$info[borrid];?>&back Time=<?php echo $info[backTime]:?>"> 续 借 </a> 
检索 读者 信息 和 读者 借阅 信息 的 SQL 语句 如 下 : 
例 程 26 ”代码 位 置 ， 光盘 \TM\07\library\bookRenew.php 


$sql=mysql query("select borr.id as borrid,borr.borrowTime,borr.back Time,borr.ifback,r.*,t.name as 
typename,t.number,book.bookname,book.price,pub.pubname,bc.name as bookcase from tb_borrow as borr join tb_reader r on 
borr.readerid=r.id join tb readerType t on rtypeid=tid join tb bookinfo as book on book.id=borr.bookid join tb publishing as 
pub on book.ISBN=pub.ISBN join tb_bookcase as bc on book.bookcase=bc.id where r.barcode=$barcode' and 
borr.ifback=0"); 
$info=mysql_fetch_array($sql); /检索 读者 信息 和 借阅 信息 


单 击 “ 续 借 ” 超 链接 ， 提 交 到 数据 处 理 页 borrow_oncemore.php， 主 要 用 于 完成 图 书 的 续 借 功 能 ， 
主要 通过 更 改 图 书 的 归还 日 期 (即将 该 图 书 的 归还 时 间 加 上 该 书 的 可 借 天 数 30 天 计算 得 出 ， 续 借 日 期 
的 具体 算法 ， 参 见 7.10.2 节 的 详细 讲解 ) 实现 。 数 据 处 理 页 的 代码 如 下 : 

例 程 27 ”代码 位 置 ， 光 盘 \TM\07\library\borrow_oncemore.php 


<?php 

session_start(); // 初 始 化 session 变 量 
include("conn/conn.php"); // 连 接 数 据 库 文件 
S$barcode=$_GET[barcode]; // 获 取 图 书 条 形 码 
Snew=$_GET[backTime]; // 获 取 图 书 归 还 时 间 


/更 新 续 借 期 ， 将 动态 获取 的 还 书 期 日 转化 为 时 间 截 ， 然 后 再 求 出 续 借 后 的 还 书 日 期 

$newbackTime=date("Y-m-d",(mktime(0, 0, 0, substr($new,5,2), substr( $new,8,2), substr($new,0,4))+3600*24*30)); 

$borrid=$_ GET[borrid]; // 获 取 续 借 图 书 的 id 号 

mysql query("update tb borrow setbackTime='$newbackTime'ifback=0.operator-'$ SESSION[admin namel' where 
id=$borrid"); 

echo "<script language='javascript>alert(' 图 书 续 借 操作 成 功 ! 
');window.location.href='bookRenew.php?barcode=$barcode';</script>"; 1/ 弹出 图 书 续 借 成 功 的 提示 信息 

> 


7.8.5 图 书 归 还 的 实现 过 程 


国 ”图 书 归 还 使 用 的 数据 表 : tb_borrow、tb_bookinfo、tb_reader 

管理 员 登 录 后 ， 选 择 “ 图 书 借 还 ”/“ 图 书 归 还 ”菜单 项 ， 进 入 到 图 书 归还 页 面 。 在 该 页 面 中 的 “ 读 
者 条 形 码 ”文本 框 中 输入 读者 的 条 形 码 (如 123456789) 后 ， 单 击 “ 确 定 ”按钮 ， 系 统 会 自动 检索 出 该 
读者 的 基本 信息 和 未 归还 的 借阅 图 书信 息 。 如 果 检 索 到 对 应 的 读者 信息 ， 则 将 其 输出 到 浏览 器 ， 此 时 
单 击 “ 归 还 ” 超 链 接 ， 即 可 将 指定 图 书 归还 。 图 书 归还 页 面 的 运行 结果 如 图 7.33 所 示 。 


RS 
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状 、 


二 上 专 图 专 绽 管理 系统 
当前 登录 的 用 户 :Tsoft 


页 。 系统 设置 ”读者 管理 。 图 书 档案 管理 。 图 书 借 还 。 系统 查询 。 更 改口 令 。 注销 


i 图 币 归 还 
读者 验证 姓 名 :而 | 性 别 :区 | 
读者 条 形 码 : 证 件 类 型 : 庄 份 证 证 件 号 码 : |Z20104123314x* ] 
[EE ] 确定 读者 类 型 公务员 可 卉 数量 ; 后 ] 册 
图 书 名 称 借阅 时 间 应 还 时 间 出 版 社 $# 织 定价 殉 ) 完成 归还 
PP 数据 库 系统 开发 完全 手册 2007-12-06 2008-01-05 人 民 邮 电 出 版 社 PIT 书架 65.00 归还 


CopyRi aht @2007 www_mrbecd com 吉林 *++ 师 范 大 学 图 书馆 
本 站 请 使 用 IE 6. 0 或 以 上 版 本 1024*768 为 最 佳 显 示 效 果 


图 7.33 ”图 书 归 还 页 面 的 运行 结果 

图 书 归 还 页 面 的 设计 方法 同 图 书 续 借 类 似 ， 所 不 同 的 是 ， 将 图 书 续 借 页 面 中 的 “ 续 借 ” 超 链接 转 
化 为 “归还 ” 超 链接 。 在 单 击 “ 归 还 ” 超 链接 时 ， 也 需要 将 读者 条 形 码 和 借阅 id 号 一 同 传递 到 图 书 归 
还 处 理 页 。 代 码 如 下 : 

例 程 28 ”代码 位 置 ， 光 盘 \TM\07\library\bookBack.php 

<a href="book Back_ok.php?borrid=<?php echo $info[borrid];?>&barcode=<?php echo $info[barcode]:?>"> 归 还 </a> 

检索 读者 信息 及 读者 借阅 信息 的 SQL 语句 如 下 : 

例 程 29 ”代码 位 置 ， 光盘 \TM\07\library\bookBack.php 


$sql=mysql_query("select borr.id as borrid,borr.borrowTime,borr.back Time,borr.ifback,r.*,t.name as 
typename,t.number,book.bookname,book.price,pub.pubname,bc.name as bookcase from tb borrow as borr join tb readerr on 
borrreaderid=rid join tb_readerType t on r.typeid=t.id join tb_bookinfo as book on book.id=borr.bookid join tb_publishing as 
pub on book.ISBN=pub.ISBN join tb bookcase as bc on book.bookcase=bc.id where r.barcode='$barcode' and 
borr.ifback=0"); 
$info=mysql_fetch_array($sql); /检索 读者 信息 及 该 读者 的 借阅 信息 


单 击 “ 归 还 ” 超 链 接 ， 即 可 将 指定 图 书 归 还 。 数 据 处 理 页 的 代码 如 下 : 
例 程 30 ”代码 位 置 ， 光盘 \TM\07\library\bookBack_ok.php 


<?php 

session_start(); // 初 始 化 session 变 量 

include("conn/conn.php"); // 连 接 数据 库 文件 

$back Time=date("Y-m-d"); /归还 图 书 日 期 

$borrid=$ GET[borrid]; /获取 读者 的 id 号 

mysql query("update tb borrow setbackTime='$backTime'ifback=1,operator-'$_ SESSION[admin_name]' where 
id=$borrid"); // 更 新 读者 的 借阅 信息 
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echo "<script language='javascript>alert(' 图 书 归 还 操作 成 功 ! 
');window.location.href='bookBack.php?barcode=$barcode';</script>"; /弹出 图 书 归 还 成 功 的 提示 信息 


> 


7.8.6 图 书 借阅 查询 的 实现 过 程 


国 书 借阅 查询 使 用 的 数据 表 : tb_borrow、tb_bookinfo、tb_reader 


管理 员 登 
阅 查 询 页 面 的 
可 以 实现 按 指 


录 后 ， 选 择 “ 系 统 查 询 ”/“ 图 书 借阅 查询 ”菜单 项 ， 进 入 到 图 书 借阅 查询 页 面 。 图 书 借 
运行 结果 如 图 7.34 所 示 。 在 该 页 面 中 可 以 按 指 定 的 字段 或 某 一 时 间 段 进行 查询 ， 同 时 还 
定 字 段 及 时 间 段 进行 综合 条 件 查询 。 


二 上 专 周 专 僻 管理 系统 


首页 


> 
当前 登录 的 用 户 : Tsoft 
系 妨 查询 


系统 设置 。 读者 管理 。 图 书 档案 管理 。 图 书 惜 还 更 改口 邻 注销 


当前 位 置 : 图 书 漠 


[中 借阅 查询 


图 书 异 阅 查 六 


请 选择 查询 依据 : 相国 书 条 形 到 到 js7654321 上 查询 
I 寞 鸭 时间: 从 |2007-05-30 JE “(日期 格式 为 : 2007-12-01) 
图 书 条 形 码 图 书 名 称 读者 条 形 码 读者 名 称 借阅 时 间 晤 时 间 ”是 否 归 还 
967854321 123456789 陈 丽 2007-12-06 2008-01-05 ”未 归还 
987654321 1255#e* 小 风 2007-12-05 2007-12-05 ”已 妇 还 
987854321 PIT 函数 考 苦 大 全 1255+# 小 几 2007-12-06 2006-01-05 ”未 归还 
CopyRight 上 @ 2007 ww.nrbecd com 吉林 +++ 师 范 大 学 图 书馆 
本 站 请 使 用 IE 6. 0 或 以 上 版 本 1024*766 为 最 佳 显示 效果 
图 7.34 图 书 借阅 查询 页 面 的 运行 结果 
图 书 借阅 查询 页 面 主要 用 于 收集 查询 条 件 和 显示 查询 结果 , 并 通过 自 定义 的 JavaScript 函数 验证 输 


入 的 查询 条 件 


是 否 合法 。 该 页 面 中 所 涉及 到 的 表单 元 素 如 表 7.5 所 示 。 
表 7.5 图 书 借阅 查询 页 面 所 涉及 的 表单 元 素 


名 称 元 素 类 型 重要 属性 含义 

myform form method="post" action="" 表单 

flagl checkbox value="a" 请 选择 查询 依据 

flag2 checkbox value="b" 借阅 时 间 
<option value="k.barcode" > 图 书 条 形 码 </option> 

a <option value="k.bookname"> 图 书 名 称 </option> 查询 字段 


<option value="r.barcode"> 读 者 条 形 码 </option> 
<option value="rname"> 读 者 名 称 </option> 
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key text size="50" 
sdate text id="sdate” 
edate text id="edate”" 


Submit submit 


在 图 书 借阅 查询 页 面 中 ,指定 查 询 条 件 后 ,提交 表单 信息 到 当前 页 。 首先 获取 表单 元 素 复 选 框 flag 
的 值 ， 然 后 根据 flag 的 值 组 合 查 询 字 符 串 。 

如 果 flagl 的 值 等 于 a， 那么 按 指定 的 字段 检索 图 书 借阅 信息 ; 如 果 flag2 的 值 等 于 b， 那 么 按 指定 
的 时 间 段 检索 图 书 借阅 信息 ; 如 果 flagl 的 值 等 于 a， 并且 flag2 的 值 等 于 b， 那 么 按 以 上 两 个 条 件 的 综 
合 条 件 检 索 图 书 借阅 信息 ， 并 将 查询 结果 输出 到 浏览 器 。 具 体 代 码 如 下 : 

例 程 31 ”代码 位 置 ， 光盘 \TM\07\library\borrowQuery.php 

<?php 

include("conn/conn.php"); // 连 接 数 据 库 文件 


$sql=mysql_query("select b.borrow Time,b.backTime,b.ifback,r.barcode as 
readerbarcode,r.name,k.id,k.barcode,k.bookname from tb_borrow b join tb_reader r on b.readerid=r.id join tb_bookinfo k on 


b.bookid=k.id"); // 查 询 图 书 借阅 信息 
if($_POST[Submit]!=""){ // 如 果 提 交 了 表单 ， 则 执行 以 下 操作 

$f=$_POSTI[f]; 1/ 获取 操作 员 选 择 的 查询 条 件 
$key1=$_POST[key1]; // 获 取 查 询 关 键 字 
$sdate=$_ POST[sdate]; // 获 取 借阅 的 起 始 日 期 
$edate=$_ POST[edate]; // 获 取 借 阅 的 结束 日 期 
S$flagl=$_POST[flag1]; // 获 取 按 指定 条 件 查询 的 复 选 框 值 
S$flag2=$_POST[flag2]; // 获 取 按 日 期 查询 的 复 选 框 值 
if(Sflag1=="a")!{ // 如 果 按 指定 条 件 查询 ， 则 执行 以 下 语句 


$sql=mysql_query("select b.borrow Time,b.backTime,b.ifback,r.barcode as 
readerbarcode,r.name,k.id,k.barcode,k.bookname from tb_borrow b join tb_reader r on breaderid=rid join tb_bookinfo k on 
b.bookid=k.id where $f like '%S$key1%"); 


} 
if(Sflag2=="b"){ // 如 果 按时 间 段 查询 ， 则 执行 以 下 语句 
$sql=mysql_query("select b.borrow Time,b.backTime,b.ifback,r.barcode as 
readerbarcode,r.name,k.id,k.barcode,k.bookname from tb_borrow b join tb_reader r on breaderid=r.id join tb_bookinfo k on 
b.bookid=k.id where borrowTime between '$sdate' and '$edate'"); 
} 
if(Sflag1=="a" && Sflag2=—"b"){ // 如 果 按 综合 条 件 查询 ， 则 执行 以 下 语句 
$sql=mysql_query("select b.borrow Time,b.backTime,b.ifback,r.barcode as 
readerbarcode,r.name,k.id,k.barcode,k.bookname from tb_borrow b join tb_reader r on b.readerid=r.id join tb_bookinfo k on 
b.bookid=k.id where borrowTime between '$sdate' and '$edate' and $f like '%S$key1%"); 


} 
Sresult=mysql_fetch_array($sqD); // 检 索 查 询 结 果 
if($result==false){ // 如 果 查 询 结果 不 存在 ， 则 弹出 提示 信息 
-> 


<table width="100%" height="30" border="0" cellpadding="0" cellspacing="0"> 
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<tr> 
<td height="36" align="center"> 暂 无 图 书 借阅 信息 ! </td> 
</tr> 
</table> 
<?php 
吕 
elsef // 否 则 ， 输 出 图 书 借阅 信息 
> 
<table width="723" border="1" cellpadding="0" cellspacing="0" bordercolor="#FFFFFF" bordercolordark="#D2E3E6" 
bordercolorlight="#FFFFFF"> 
<tr align="center" bgcolor="#DOE9F8"> 
<td width="13%"> 图 书 条 形 码 </td> 
<td width="27%"> 图 书 名 称 </td> 
<td width="15%"> 读 者 条 形 码 </td> 
<td width="11%"> 读 者 名 称 </td> 
3%"> 借 阅 时 间 </td> 
1%"> 归 还 时 间 </td> 
<td width="10%"> 是 否 归还 </td> 
</tr> 
<2php 
dof 
if(Sresultlifback]=="0"){ // 如 果 “ 是 否 归 还 ”等 于 0， 则 输出 “未 归还 ” 
$ifbackstr=" 未 归还 "; 


} 
elsef // 如 果 “ 是 否 归 还 ”等 于 1， 则 输出 “已 归还 ” 
$ifbackstr=" 已 归还 "; 
Bb 
?> 
/本 中 于 站 叶 于 守则 刘 素 于 宙 下 束 来 于 于 于 中环 村 于 于 呈 站 于 让 中 贡生; 和合 查询 条件 所 杂 本 本 中 本 于 员 本 于 村 本 于 本 下 半球 末 虽 于 束 浊 环球 冰球 于 水球 间 于 六 / 
<tr> 
<td style="padding:5px:">&nbsp:;<?php echo $result[barcode];?></td> 
<td style="padding:5px;"><a href="book_look.php?id=<?php echo $result[id]; ?>"><?php echo 
$result[bookname];?></a></td> 
<td style="padding:5px;">&nbsp;<?php echo $result[readerbarcode];?></td> 
adding:S5px;">&nbsp;<?php echo $result[name];?></td> 
adding:5px;">&nbsp;<?php echo $result[borowTime];?></td> 
<td style="padding:5px;">&nbsp;<?php echo $result[backTime];?></td> 
<td style="padding:5px;">&nbsp;<?php echo $ifbackstr;?></td> 
</t> 
/中 六 守 六 六 闪 六 闪 半 六 闪 六 半 六 闪 闵 六 闪闪 闪闪 六 闪闪 六 六 六 闪 六 闪 妆 闪闪 闪 闪闪 闪闪 闪闪 闪闪 闪闪 率 率 闪 六 站 这 六 率 站 率 六 六 率 率 半 六 六 六 率 六 冰 半 / 


<?php 
}while(Sresult=mysql_fetch_array($sqD)); 


}; 
> 


7.8.7 单元 测试 


在 开发 完 图 书 借 还 模块 后 ， 对 该 模块 进行 了 单元 测试 。 当 操作 员 按 指定 字段 进行 条 件 查 询 时 ， 能 


.368 
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够 实现 图 书 借阅 查询 ， 当 操作 员 按 指 定 的 时 间 段 进行 查询 时 ， 也 能 够 实现 图 书 借阅 查询 ; 但 是 当 操作 
员 按 以 上 两 个 条 件 同时 进行 查询 时 ， 则 不 能 实现 图 书 借阅 查询 。 
图 书 借 还 模块 的 表单 元 素 代 码 如 下 : 


<input name="flag" type="checkbox" class= "noborder" value="a" checked> 
<input name="flag" type="checkbox" class="noborder" id="flag" value="b"> 


完成 图 书 借阅 查询 的 SQL 语句 如 下 : 


if(Sflag 一 "a"){ 
$sql=mysql_query("select b.borrow Time,b.backTime,b.ifback,r.barcode as 
readerbarcode,r.name,k.id,k.barcode,k.bookname from tb borrow b join tb reader r on b.readerid=r.id join tb bookinfo k on 
b.bookid=k.id where $f like %$key1%0); 


} 
if(Sflag—="b"){ 
$sql=mysql query("select b.borrowTime,b.backTime,b.ifback,rbarcode as 
Treaderbarcode,r.name,k.id,k.barcode,k.bookname from tb borrow b join tb_reader r on b.readerid=r.id join tb_bookinfo k on 
b.bookid=k.id where borrowTime between '$sdate' and '$edate'"); 
} 
if($flag 一 "a" && Sflag=="b")! 
$sql=mysql_query("select b.borrow Time,b.backTime,b.ifback,r.barcode as 
Teaderbarcode,r.name,k.id,k.barcode,k.bookname from tb borrow b join tb reader r on b.readerid=r.id join tb bookinfo k on 
b.bookid=k.id where borrowTime between '$sdate' and '$edate' and $f like '%$key1%"); 


} 

为 了 找 出 错误 的 原因 ， 笔 者 应 用 echo0) 语 句 对 $flag 的 值 进行 输出 ， 输 出 的 结果 显示 $flag 等 于 b， 
不 执行 $flag 等 于 a。 这 充分 说 明 在 对 同名 复 选 框 进行 查询 时 ， 它 只 能 获取 最 后 一 个 复 选 框 的 值 。 

解决 该 问题 的 方法 是 将 两 个 复 选 框 分 别 定义 为 两 个 不 同 的 名 称 ， 然 后 赋予 不 同 的 值 ， 再 进行 判断 ， 
就 可 以 实现 按 指 定 字 段 、 指 定 的 条 件 进 行 综合 条 件 查询 了 。 

因此 将 表单 中 的 HTML 标记 中 的 flag 进行 重 命名 ， 代 码 如 下 : 


<input name="flagl" type="checkbox" class="noborder" value="a" checked> 
<input name="flag2" type="checkbox" class="noborder" id="flag" value="b"> 


多 改 后 的 完成 图 书 借阅 查询 的 SQL 语句 如 下 : 


if(Sflag1l=="a")! 
$sql=mysql_query("select b.borrow Time,b.backTime,b.ifback,r.barcode as 
readerbarcode,r.name,k.id,k.barcode,k.bookname from tb borrow b join tb reader r on b.readerid=r.id join tb bookinfo k on 
b.bookid=k.id where $f like "$key1%"); 
} 
if(Sflag2=="b"){ 
$sql=mysql query("select b.borrowTime,b.backTime,b.ifback,r.barcode as 
readerbarcode,r.name,k.id,k.barcode,k.bookname from tb_borrow b join tb_reader r on breaderid=rid join tb_bookinfo k on 
b.bookid=k.id where borrowTime between '$sdate' and '$edate'"); 
} 
if(Sflagl=="a" && Sflag2=="b")! 
$sql=mysql_query("select b.borrow Time,b.backTime,b.ifback,r.barcode as 
readerbarcode,r.name,k.id,k.barcode,k.bookname from tb borrow b join tb reader r on b.readerid=r.id join tb bookinfo k on 
b.bookid=k.id where borrowTime between '$sdate' and '$edate' and $f like '%S$key1%"); 
} 
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7.9 开发 技巧 与 难点 分 析 


7.9.1 如 何 自动 计算 图 书 归还 日 期 


在 图 书馆 管理 系统 中 会 遇 到 这 样 的 问题 : 在 借阅 图 书 时 ， 需 要 自动 计算 图 书 的 归还 日 期 。 

1. 图 书 归 还 日 期 

根据 图 书馆 还 书 的 规律 一 般 都 以 30 天 为 一 个 期 限 ， 因 此 在 图 书 归 还 时 ， 可 以 设置 一 个 固定 的 值 
即 30 天 。 计 算 归还 日 期 的 方法 如 下 : 

图 书 归还 日 期 =“ 系 统 当前 日 期 ”+“ 借 阅 天 数 固定 值 30 天 ”。 

自动 计算 图 书 归 还 日 期 的 具体 代码 如 下 : 

date("Y-m-d",(time()+3600*24*30)) // 图 书 归还 日 期 

2. 续 借 图 书 归 还 日 期 

续 借 图 书 归还 日 期 是 在 原来 数据 库 保存 该 图 书 归还 日 期 (这 个 日 期 是 不 固定 的 ) 的 基础 上 而 再 次 借 
阅 所 计算 的 时 间 ， 它 是 需要 根据 数据 表 中 保存 归还 日 期 来 计算 的 。 计 算 图 书 续 借 归还 日 期 的 方法 如 下 

续 借 图 书 归 还 日 期 =“ 所 借 图 书 在 数据 表 中 的 归 回 日 期 ”+“ 借 阅 天 数 固定 值 30 天 ”。 

首先 应 用 substr(O) 函 数 分 别 取出 所 借 图 书 在 数据 表 中 原 定 的 归还 日 期 “月 ”、“ 日 ”、“ 年 ”， 然 
后 应 用 mktimeO 函 数 计算 出 归还 日 期 的 时 间 戳 ， 最 后 应 用 date(O) 函 数 格式 化 日 期 为 “YYYY-MM-DD” 
格式 。 自 动 计算 续 借 图 书 归还 日 期 的 代码 如 下 

Snew=$_GET[backTime]; // 获 取 传递 过 来 的 该 图 书 在 数据 表 中 的 归还 日 其 


/更 新 续 借 期 ， 将 动态 获取 的 还 书 期 日 转化 为 时 间 截 ， 然 后 再 求 出 续 借 后 的 还 书 日 期 
date("Y-m-d",(mktime(0, 0, 0, substr(Snew,5,2), substr(Snew,8,2), substr($new,0,4))+3600*24*30)); 


7.9.2 如何 对 图 书 借阅 信息 进行 统计 排行 


在 图 书馆 管理 系统 的 首页 中 ， 提 供 了 显示 图 书 借阅 排行 榜 功 能 。 要 实现 该 功能 ， 最 重要 的 是 如 何 
获取 统计 排行 信息 ,这 可 以 通过 一 条 SQL 语句 实现 本 系统 中 实现 对 图 书 借阅 信息 进行 统计 排行 的 SQL 
语句 如 下 : 

select * from (select bookid,count(bookid) as degree from tb borrow group by bookid) as borr join (select b.*,c.name as 
bookcasename,p.pubname,t.typename from tb bookinfo b left join tb bookcase ¢ on b.bookcase=c.id join tb publishing p on 
b.ISBN=p.ISBN join tb booktype t on b.typeid=t.id where b.del=0) as book on borr.bookid=book.id order by borr.degree desc 
limit 10 

下 面 将 对 该 SQL 语句 进行 分 析 : 

(1) 对 图 书 借阅 信息 表 进行 分 组 并 统计 每 本 图 书 的 借阅 次 数 ， 然 后 使 用 as 为 其 指定 别名 为 borr。 
代码 如 下 : 
(Select bookid,count(bookid) as degree from tb_borrow group by bookid) as borr 


Sa 
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(2) 使 用 左 联接 查询 出 图 书 的 完整 信息 ， 然 后 使 用 as 为 其 指定 别名 为 book。 代 码 如 下 : 
(select b.*,c.name as bookcasename,p.pubname.t.typename from tb bookinfo b left join tb bookcase c on b.bookcase=c.id 
join tb_publishing p on b.ISBN=p.ISBN join tb_booktype ton b.typeid=t.id where b.del=0) as book 
(3) 使 用 join on 语句 将 borr 和 book 连接 起 来 ， 再 对 其 按 统 计 的 借阅 次 数 degree 进行 降序 排序 ， 
并 使 用 limit 子 句 限制 返回 的 行 数 。 


7.10 ”联接 语句 技术 专题 


在 实际 网 站 开发 过 程 中 ， 经 常 需要 从 多 个 表 中 查询 信息 ， 在 MySQL 数据 库 中 可 以 通过 连接 的 方 
式 实现 多 表 查 询 ， 连 接 方 式 分 为 内 联接 和 外 联接 两 种 。 下 面 对 这 两 种 连接 方式 进行 详细 的 讲解 。 


7.10.1 内 联接 语句 


inner join 即 内 联接 查询 方式 ， 是 程序 开发 中 常用 的 连接 方式 。 内 联接 称 为 相等 联接 。 它 返回 两 个 
表 中 的 所 有 列 ， 但 只 返回 在 联接 列 中 具有 相等 值 的 行 。 内 联接 查询 的 语法 格式 如 下 : 
select fieldlist 


他 om tablel [inner] join table2 
on tablel.column=table2.column 


参数 说 明 : 

fieldlist: 要 查询 的 字段 列表 。 

tablel 、table2: 为 要 连接 的 表 名 。 

inner: 可 选项 ， 表 示 表 之 间 的 连接 方式 为 内 联接 。 

on tablel.column1=table2.column2: 用 于 指明 表 tablel 和 表 table2 之 间 的 连接 条 件 。 

下 面 通过 内 联接 方式 实现 员工 信息 表 和 员工 工资 表 的 连接 ， 并 显示 查询 结果 。 代 码 如 下 : 
$sql=mysql_query("select tb_yg.userid,tb yg.name,tb_yg.sex,tb yg.age,tb_yg.tel,tb_yg.bm,tb yg _info.gz from tb yg 


inner join tb yg info on tb yg.userid=tb yg info.ygid"); 
Sinfo=mysql_fetch_array($sql); 


7.10.2 ”外 联接 语句 


内 联接 返回 的 是 两 个 表 中 符合 条 件 的 数据 ， 而 外 联接 返回 部 分 或 全 部 匹配 行 ， 这 主要 取决 与 所 建 
立 的 外 联接 的 类 型 。 外 联接 分 为 左 外 联接 和 右 外 联接 ， 下 面 对 两 个 外 联接 的 使 用 方法 进行 详细 讲解 。 
1. 左 外 联接 (left outer join) 
左 联 接 返 回 的 查询 结果 包含 左 表 中 的 所 有 符合 查询 条 件 及 右 表 中 所 有 满足 连接 条 件 的 行 。MySQL 
数据 库 中 使 用 左 联 接 的 语法 格式 如 下 : 
"371。 乡 


Select field 1[field2…] 
from tablel left [outer] join table2 
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on join condition 

[where search_condition] 

参数 说 明 : 

left outer join: 表示 表 之 间 通 过 左 联接 方式 相互 连接 ， 也 可 以 简写 成 leftjoin。 

onjoin_condition: 指 多 表 建 立 连接 所 使 用 的 连接 条 件 。 

where search_condition: 可 选项 ， 用 于 设置 查询 条 件 。 

下 面 通过 左 外 联接 的 方式 建立 员工 信息 表 和 员工 工资 表 的 连接 ， 并 显示 查询 结果 。 代 码 如 下 : 

$sql=mysql query("select * from tb yg left outer join tb yg info on tb yg.userid=tb yg info.ygid ",$conn); 

$info=mysql_fetch_array($sql); 

2. 右 外 联接 (right outer join) 

右 联接 返回 的 查询 结果 包含 左 表 中 的 所 有 符合 连接 条 件 以 及 右 表 中 所 有 满足 查询 条 件 的 行 。 
MySQL 数据 库 中 使 用 右 联接 的 语法 格式 如 下 : 


Select field 1[field2…] from tablel right [outer] join table2 on join_condition [where search_condition] 


参数 说 明 : 

right outer join: 表示 表 之 间 通 过 左 联接 方式 相互 连接 ， 也 可 以 简写 成 right join。 
outer: 可 选项 ， 表 示 表 之 间 的 联接 方式 为 完全 联接 。 

on join_condition: 指 多 表 建 立 联接 所 使 用 的 连接 条 件 。 

where search_condition: 可 选项 ， 用 于 设置 查询 条 件 。 

下 面 通过 右 外 联接 建立 员工 信息 表 和 员工 工资 表 的 连接 ， 并 显示 查询 结果 。 代 码 如 下 : 
$sql=mysql query("select * from tb yg right outer join tb yg info on tb yg.userid=tb yg info.ygid "); 
S$info=mysql_fetch_array($sql); 


7.11 本 章 总 结 


本 章 运 用 软件 工程 的 设计 思想 ， 通 过 一 个 完整 的 图 书馆 管理 系统 引导 读者 深入 了 解 系统 的 开发 流 
程 。 在 这 个 系统 的 实现 过 程 中 ， 除 了 应 用 一 些 基 本 的 PHP 技术 之 外 ， 还 涉及 一 些 独特 的 技术 细节 ， 如 
权限 设置 、 多 表 查 询 技术 等 需要 读者 掌握 ， 并 能 在 实际 的 操作 中 灵活 应 用 ， 举 一 反 三 。 
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如 果 有 人 问 “ 什 么 是 Web2.0? ”， 怒 怕 没 几 个 人 能 说 得 清楚 ， 但 是 要 问 什么 
是 博客 ， 哪 怕 是 从 不 上 网 的 人 也 是 耳熟能详 的 了 。 博 客 正 是 Web2.0 概念 中 重要 的 
组 成 部 分 之 一 (大 家 熟知 的 还 包括 IM 即时 通 和 RS99 阅读 器 ) 。 

Blog (博客 ) ， 全 名 Weblog， 后 来 缩写 为 Blog。Blogger 就 是 写 Blog 的 人 ， 
习惯 于 在 网 上 写 出 上 日记、 发 布 个 人 照片 、 展 示 个 性 自我 的 用 户 群体 。 对 于 
Blog/Blogger 的 中 文 名 称 ， 有 翻译 成 “博客 ”， 也 有 翻译 为 “网 志 ”， 但 大 多 数 人 
都 已 经 认可 了 “博客 ”。 

通过 阅读 本 章 ， 读 者 可 以 学 到 : 


博客 管理 系统 的 开发 流程 

进一步 掌握 如 何 做 项 目 需求 分 析 与 系统 设计 

实现 一 个 简单 的 公告 栏 管理 模块 

掌握 不 同 的 图 片上 传 技 术 

掌握 一 种 采用 JavaScript+CSS 技术 来 实现 的 半 透 明 动 态 下 拉 菜单 


豆 吾 吾 吾 至 
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8.1 开发 青 景 


博客 管理 系统 给 人 们 提供 抒发 个 人 情感 、 人 与 人 之 间 进 行 良好 沟通 的 平台 , 博客 拥有 真实 的 内 容 ， 
可 以 通过 博客 记录 下 工作 、 学 习 、 生 活 和 娱乐 的 点 滴 ， 以 及 发 表 文 章 和 评论 ， 从 而 在 网 上 建立 一 个 完 
全 属于 自己 的 个 人 天 地 ， 成 为 当今 网 络 最 为 个 性 化 和 平民 化 的 个 人 展示 空间 。 对 于 网 民 ， 只 要 拥有 博 
客 ， 就 可 以 超越 现实 生活 ， 拥 有 不 同 以 往 的 全 新 网 上 生活 ， 对 于 博客 服务 商 ， 则 必须 从 功能 提供 转型 
到 全 方位 社会 服务 的 提供 ， 建 立 虚拟 社会 ， 并 负责 维护 运行 ， 保 证 博客 日 常生 活 ， 对 于 社会 而 言 ， 有 
利于 构建 和 谐 的 互联 网 空间 ， 维 护 和 谐 的 社会 环境 。 从 这 个 角度 来 说 ， 构 建新 生活 方式 ， 将 是 互联 网 
发 展 的 一 个 里 程 碑 。 


8.2 ”需求 分 析 


信息 时 代 的 今天 ， 博 客 已 经 成 为 一 种 新 的 生活 方式 。 在 网 络 中 构建 一 个 赋 有 个 性 化 的 个 人 博客 ， 
提供 了 一 种 可 信任 的 和 实时 连通 的 网 络 环 境 ， 通 过 网 络 开放 性 和 交互 性 的 特点 ， 让 用 户 在 任何 时 间 、 
任何 地 点 ， 通 过 网 络 方便 地 “生活 ”， 不 仅 是 信息 传递 与 获取 ， 还 可 以 进行 群体 交流 和 资源 共享 ， 展 
示 自 我 ， 为 个 人 发 展 带 来 新 机 遇 。 

通过 对 多 个 博客 网 的 调查 分 析 ， 客 户 要 求 本 博客 管理 系统 具有 以 下 功能 : 
要 求 系统 采用 B/S 架构 ， 实 现 人 机 交互 。 
要 求 系统 界面 个 性 化 ， 色 彩 搭配 和 谐 ， 很 强 的 视觉 冲击 力 ， 操 作 简 便 。 
要 求 突出 主题 ， 显 示 最 新 文章 和 公告 。 
要 求 游客 可 以 浏览 文章 、 浏 览 图 片 、 发 表 评 论 。 
要 求 具有 强大 的 搜索 查询 功能 ， 实 现 精确 查询 和 模糊 查询 。 
完善 的 文章 管理 功能 ， 包 括 文章 的 发 表 、 删 除 ， 及 对 文章 的 评论 与 回复 。 
支持 图 片上 传 功能 ， 可 以 上 传 各 种 类 型 的 图 片 。 
支持 好 友 功能 。 
系统 运行 稳定 ， 安 全 可 靠 。 


办 办 办 办 办 办 办 多 


8.3 系统 设计 


8.3.1 系统 目标 


该 系统 主要 实现 如 下 目标 : 


Sa 


第 8 章 博客 管理 系统 (Apache+PHP+phpMyAdmin+MySQL 5.0 实现 ) 


系统 采用 B/S 架构 ， 实 现 人 机 交互 。 

系统 界面 设计 以 浅 色 为 主 ， 美 观 友 好 ， 操 作 简便 。 

突出 重点 内 容 ， 显 示 最 新 文章 。 

非 登 录用 户 可 以 浏览 文章 、 浏 览 图 片 、 发 表 评论 。 

全 面 的 搜索 查询 功能 ， 包 括 精确 查询 和 模糊 查询 。 

完善 的 文章 管理 功能 ， 包 括 文章 的 发 表 、 删 除 ， 及 对 文章 的 评论 与 回复 。 
支持 图 片上 传 功能 。 

支持 好 友 功能 。 

支持 公告 栏 功能 。 

系统 运行 稳定 ， 安 全 可 靠 。 


因 办 办 办 办 办 办 办 办 


8.3.2 系统 功能 结构 


博客 管理 系统 的 功能 结构 如 图 8.1 所 示 。 


[Eb 
岗 磅 霸 闪 


图 8.1 博客 管理 系统 功能 结构 图 
8.3.3 系统 功能 预览 


为 了 让 读者 对 本 系统 有 个 初步 的 了 解 和 认识 ， 下 面 给 出 本 系统 的 儿 个 页 面 运行 效果 图 ， 如 果 想 查 
看 完整 的 效果 图 ， 请 参见 光盘 源 程序 。 

博客 管理 系统 的 首页 如 图 8.2 所 示 , 该 页 面包 含 了 系统 大 部 分 的 功能 链接 , 包括 用 户 注册 、 用 户 登 
录 、 文 章 浏览 等 。 用 户 注册 页 面 如 图 8.3 所 示 ， 该 页 面 显示 了 用 户 注册 时 需要 填写 的 资料 、 注 意 事项 
等 。 

浏览 文章 页 面 如 图 8.4 所 示 , 该 页 面 用 于 显示 文章 及 相关 的 评论 , 也 可 以 发 表 评 论 。 发 表 文 章 页 面 
如 图 8.5 所 示 ， 该 页 面 用 于 登录 用 户 发 表 文章 ， 包 括 文章 标题 、 文 字 编 辑 区 和 文章 内 容 。 

“5. 
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图 8.4 ”浏览 文章 页 面 ( 光 盘 \TM\08\online\article.php) ”图 8.5 ”发 表 文 章 页 面 (光盘 \TM\08\online\file.php) 


图 片上 传 页 面 用 于 上 传 图 片 ， 如 图 8.6 所 示 , 通过 该 页 面 用 户 可 以 将 图 片 或 照片 添加 到 博客 中 。 添 
加 好 友 页 面 如 图 8.7 所 示 ， 该 页 面 用 于 输入 用 户 好 友 的 详细 信息 ， 包 括 姓 名 、 性 别 、 生 日 等 。 


EE 


图 8.6 图 片上 传 页 面 (光盘 \TM\08\online\add_pic.php) ”图 8.7 添加 好 友 页 面 (光盘 \TM\08\online\friendd.php) 


8.3.4 系统 流程 图 


博客 管理 系统 的 流程 图 如 图 8.8 所 示 。 
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上 典 古 玉 悄 


图 8.8 ”系统 流程 图 


8.3.5 开发 环境 


在 开发 博客 管理 系统 平台 时 ， 该 项 目 使 用 的 软件 开发 环境 如 下 : 
。 服务 器 端 

操作 系统 : Windows Server 2003 

服务 器 : Apache 2.0。 

PHP 软件 : PHP 5.0。 

数据 库 : MySQL 5.0。 

MySQL 图 形 化 管理 软件 : PhpMyAdmin-2.5.5。 
开发 工具 : Dreamweaver 8。 

浏览 器 : IE 6.0。 

分 辨 率 : 最 佳 效 果 1024X 768 像素 。 
客户 端 

浏览 器 : 推荐 使 用 IE 6.0 及 以 上 版 本 。 

分 辨 率 : 最 佳 效 果 1024X 768 像素 。 


wb 


加 图 图 加 图 图 加 加 


R 


加 回 


8.3.6 ”文件 夹 组 织 结构 


博客 系统 的 目录 比较 少 ， 结 构 比 较 简 单 ， 主 要 有 数据 库 链 接 文 件 目录 、css 样式 目录 、js 脚本 目录 
及 背景 图 片 目录 。 文 件 夹 组 织 结构 如 图 8.9 所 示 。 
“377。 g 
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EB tnlog 
| 回 [om 数据库 链接 交 件 
i 加 css css 样 式 文件 
四 :加 inages - 图 片 背景 目录 
由 -名 了 javaseript 脚 本 文件 


8.9 博客 管理 系统 文件 夹 组 织 结构 


8.4 数据 库 设 计 


8.4.1 数据 库 分析 


本 系统 属于 中 小 型 个 人 网 站 ， 毫 无 争议 的 ， 本 系统 采用 的 依然 是 PHP+MySQL 这 对 儿 黄 金 组 合 ， 
无 论 是 从 成 本 、 性 能 、 安 全 上 考虑 ， 还 是 从 易 操 作 性 上 考虑 ，MySQL 都 是 最 佳 选 择 。 


8.4.2 数据库 概 念 设计 


通过 需求 分 析 和 功能 上 的 设计 ， 本 系统 规划 出 用 户 信息 实体 、 上 传 图 片 实体 、 朋 友 圈 实体 、 文 章 
实体 和 留言 实体 。 下 面 给 出 主要 的 实体 及 E-R 图 。 

用 户 信息 实体 包括 注册 用 户 的 详细 个 人 信息 ， 如 果 想 在 本 系统 中 进行 发 表 文章 、 上 传 图 片 等 操作 ， 
则 必须 要 先进 行 注 。 用 户 信息 实体 E-R 图 如 图 8.10 所 示 。 


登记 时 间 


图 8.10 用 户 信息 实体 E-R 图 


上 传 图 片 实体 主要 包括 上 传 图 片 的 名 称 、 上 传 图 片 用 户 和 上 传 图 片 时 间 等 ， 实 体 E-R 图 如 图 8.11 
所 示 。 


Re 
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图 8.11 


8.4.3 ”数据库 物理 结构 设计 


根据 实体 E-R 图 和 本 系统 的 实际 情况 ， 需 要 创建 6 张 数据 表 ， 如 图 8.12 所 示 。 


图 片 空间 


上 传 图 片 实体 E-R 


加 服务 器 : localhost 将 数据 库 : db_tmlog 


th_article 
th_filecomment 
th_friend 
tb_public 
tb_tpsc 
th_user 


类 型 整理 
MYISAM 。 gb2312_chinese_ci 
MYISAM = gb2312_chinese_ci 
MYISAM = gb2312_chinese_ci 
MyISAM 。 gb2312_chinese_ci 
MYISAM = gb2312_chinese_ci 
MyISAM 。 gb2312_chinese_ci 


8.12 ”数据 表 列表 


下 面 来 具体 看 一 下 这 6 张 数据 表 的 结构 设计 。 


1. tb_user (用 户 列表 ) 


说 明 
文章 列表 


用 户 列表 主要 存储 用 户 的 个 人 信息 。tb_user 表 的 结构 如 图 8.13 所 示 。 


胃 服务 器 : localhost 〉 章 数据 库 : db_tmlog ， 国 表 :tb_user 


字 肪 


int(20) 
varchar(20) 
varchar(20) 
varchar(40) 
date 
varchar(100) 
Yarchar(100) 
varchar(50) 
Yarchar(4) 
varchar(40) 
varchar(100) 
varchar(200) 
mediumtext 
varchar(20) 
int(1) 


gb2312_chinese_ci 
9b2312_chinese_ci 
gb2312_chinese_ci 


9b2312_chinese_ci 
gb2312_chinese_ci 
gb2312_chinese_ci 
gb2312_chinese_ci 
gb2312_chinese_ci 
gb2312_chinese_ci 
9b2312_chinese_ci 
gb2312_chinese_ci 
gb2312_chinese_ci 


天 节 呈 天 呈 吓 节 呈 吓 瑚 呈 呈 呈 呈 吓 


图 8.13 用 户 列表 结构 


默认 


0000-00-00 
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2. tb_article (文章 列表 ) 
文章 列表 存储 的 是 用 户 发 表 过 的 文章 信息 。tb_article 表 的 结构 如 图 8.14 所 示 。 
加 服务 器 : localhost ， 晶 数据 库 : db_tmlog 图 表 :tb_article 


字段 类 型 整理 = Null 默认 说 明 
id intt10) 否 自动 编号 
title Yarcharf200) gb2312_chinese_ci 文章 标题 
content mediumtext gb2312_chinese_ci 否 文章 内 容 
author varchar(20) gb2312_chinese_ci 否 文章 作者 
now datetime 和 理 0000-00-00 00:00:00 上 传 时 间 


图 8.14 文章 列表 结构 
3. tb_filecomment (评论 列表 ) 
评论 列表 存储 的 是 用 户 对 文章 的 评论 , 包括 注册 用 户 和 游客 都 可 以 发 表 评论 。tb_filecomment 表 的 
结构 如 图 8.15 所 示 。 


回 服务 器 : localhost ， 虽 数据 库 : db_tmlog ， 


表 :tb_filecomment 


字段 类 型 整理 = Null 默认 说 明 
id int(4) 否 自动 编号 
fileid int4) 否 0 文章 id 
username varchar(20) gb2312_chinese_ci 否 评论 用 户 
content text gb2312_chinese_ci 否 评论 内 容 
datetime 。 datetime 否 0000-00-0000:00:00 ”评论 时 间 


图 8.15 评论 列表 结构 
4. tb_tpsc (图 片 列表 ) 
图 片 列表 存储 的 是 上 传 图 片 的 信息 ， 如 图 片 名 称 、 上 传 用 户 、 上 传 时间 等 。tb tpsc 表 的 结构 如 
图 8.16 所 示 。 
较 服务 器 : localhost ， 曲 数据 库 : db_tmlog ， 国 表 :tb_tpsc 


字段 类 型 整理 尾 性 Null 默认 说 明 
这 intt10) 否 自动 编号 
tpmc varchar(30) gb2312_chinese_ci 否 图 片 名 称 
file mediumblob BINARY 殖 二 进 制 图 片 
author varchar(20) gb2312_chinese_ci 否 上 和 薛 用 户 
scsj date 否 。 0000-00-00 ”上 传 时 间 


图 8.16 ”图片 列表 结构 
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5. tb_friend (好 友 列 表 ) 


好 友 列 表 主 要 记录 了 姓名 、 性 别 、 生 日 等 好 友 的 个 人 信息 。tb_friend 表 的 结构 如 图 8.17 所 示 。 


加 服务 器 : localhost ” 蝇 数据 库 : db_tmlog 图 
字段 类 型 整理 尾 性 Null 
id int4) 否 
name varchar(50) gb2312_chinese_ci 否 
Sex varchart10) gb2312_chinese_ci 六 | 
bir date 否 
city varchar(50) gb2312_chinese_ci 否 
address warchar(100) gb2312_chinese_ci 否 
postcode varchar(6) gb2312_chinese_ci 否 
email yarchar(50) gb2312_chinese_ci 否 
tel Yarchar(20) gb2312_chinese_ci 再 
handset varchar(20) gb2312_chinese_ci 否 
QQ varchar(20) gb2312_chinese_ci 否 
username varchar(20) gb2312_chinese_ci 否 


图 8.17 好 友 列 表 结 构 


6. tb_public (公告 列表 ) 


表 :tb_friend 


默认 说 明 

自动 编号 
好 友 姓 名 
好 友 性 别 

0000-00-00 ”好 友 生 日 
所 在 城市 
家 庭 住址 
邮政 编码 
E-mail 
座机 号 码 

0 手机 号 码 

0 好 友 QQ 
用 户 昵 称 


公告 列表 主要 记录 了 网 站 情况 、 博 客 系统 的 版 本 情况 或 是 网 站 活动 等 等 。 公告 列表 的 结构 如 图 8.18 


所 示 。 
胃 服务 器 : localhost ， 曲 数据 库 : db_tmlog 图 表 :tb_public 
字段 类 型 整理 尾 性 Null 默认 说 明 
这 intf4) 否 自动 编号 
title varchart50) gb2312_chinese_ci 公告 : 
content varchar(200) gb2312_chinese_ci 否 公告 内 容 
pub_time date 否 发 布 时 间 


图 8.18 公告 列表 结构 


8.5 首页 设计 


8.5.1 首页 概述 


本 系统 首页 页 面 设计 简洁 ， 主 要 包括 以 下 3 部 分 内 容 : 
回 首部 导航 栏 : 包括 首页 链接 、 注 册 和 登录 模块 。 


“1. 
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回 “ 左 侧 显示 区 : 包括 最 新 文章 、 最 新 图 片 和 系统 时 间 模块 。 游 客 主要 通过 该 区 域 浏览 文章 、 济 
览 图 片 及 发 表 评论 。 
主 显示 区 : 为 系统 公告 栏 ， 显 示 系 统 及 网 站 的 最 新 咨询 。 
下 面 看 一 下 本 案例 中 提供 的 首页 , 该 首页 在 本 书 光 副 中 的 路 径 为 \TM\08\tmlog\index.php, 如 图 8.19 
所 示 。 


. 

5 179 
11 12 13 国 15 
18 19 20 21 22 
25 26 27 28 29 


热烈 庆祝 BCCD 博 客 网 重新 开放 


图 片 名 称 ; 可 爱 的 小 免 子 


图 8.19 博客 管理 系统 首页 


8.5.2 首页 技术 分 析 


在 首页 主 显示 区 ， 是 一 个 公告 栏 模块 。 公 告 栏 主要 用 于 公布 系统 版 本 的 更 新 或 升级 情况 、 网 站 的 
最 新 活动 安排 等 ， 也 可 以 链接 一 些 用 户 的 精彩 文章 。 本 系统 的 公告 栏 模块 是 通过 <marquee> 标 签 来 实现 
的 。<marquee> 标 签 是 HTML 自 带 的 、 也 是 初学 者 最 常用 的 公告 栏 实现 方式 。 使 用 <marquee> 标 签 ， 可 
以 实现 文字 或 图 片 的 深 动 效果 ， 增 加 了 实用 性 的 同时 ， 也 增加 了 观赏 性 。 下 面 就 来 学 习 一 下 这 个 标签 
的 常用 方法 及 属性 。 
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全 注意 : <marquee> 标 签 是 微软 与 网 景 等 公司 私 制 的 ， 从 来 没有 被 W3C 当 作 正式 标签 来 使 用 ， 所 以 
除了 下 浏览 器 外 ， 有 些 属 性 是 不 被 其 他 浏览 器 所 支持 的 。 在 使 用 时 一 定 要 留意 。 

1. <marquee> 标 签 的 文字 移动 属性 

<marquee> 标 签 的 特点 就 是 可 以 是 文字 或 图 片 动 起 来 ， 在 早 些 时 候 ， 这 可 是 一 个 了 不 起 的 技术 。 随 

着 W3C 标准 的 逐渐 完善 ，<marquee> 标 签 已 经 越 来 越 少 有 用 武之 地 了 ， 但 有 些 技术 是 永远 不 变 的 ， 比 


如 <marquee> 标 签 中 属性 名 称 和 属性 值 ， 了 解 css 样式 表 和 JavaScript 脚本 语言 的 人 会 感觉 到 非常 熟悉 ， 
因为 这 些 属性 名 称 和 属性 值 都 经 常 被 提 及 和 使 用 。<marquee> 标 签 用 的 文字 移动 属性 及 属性 值 ， 如 
表 8.1 所 示 。 
表 8.1 <marquee> 标 签 常用 的 文字 移动 属性 及 说 明 
属性 名 称 属 性 值 属性 说 明 应 用 举例 
marquee 无 > 障 了 区 站 可 及 二 <marquee> 你 好 ，PHP</marquee> 
ga] 
ee et 文字 移动 属性 ， 分 别 表示 从 右 往 左 、 从 | <marquee direction="up"> 从 下 到 上 移 
irection eft,right,up,down 左 往 右 、 从 下 到 上 、 从 上 到 下 动 <marquee> 
文字 移动 方式 ， 分 别 表示 沿 同一 方向 不 es 
behavior scroll,slide,altemate | 停 滚动 、 只 滚动 一 次 、 在 两 个 边界 内 来 ages behavimegal 不 停 的 
回 滚动 循环 播放 </marquee> 
K S i <marquee loop=5 behavior=slide> 只 
loop 数值 1.223 循环 次 数 ， 不 指定 则 表示 为 无 限 循环 | 全 未 深 功 3 次 ne 
serollmount | 数值 10.20.30…。 | 滚动 速度 ， 数 值 越 大 ， 速 度 越 忆 2 八条 
了! ! <marquee> 
<marquee scrolldelay="500" 
Scrolldelay 数值 100,200,300… | 延 时 ， 每 动 一 次 ， 停 止 的 时 间 scrollamount=100> 停 停 走 走 


2. <marquee> 标 签 的 外 观 设置 
<marquee> 标 签 不 仅 可 以 设置 文字 移动 效果 , 还 能 设置 标签 的 外 观 。 外 观 包括 对 齐 方式 、 标签 底 色 、 
面积 等 。<marquee> 标 签 常用 的 外 观 属性 及 说 明 如 表 8.2 所 示 。 


align 


</marquee> 


表 8.2 <marquee> 标 签 常用 的 外 观 设置 属性 及 说 明 


top:middle'bottom 


指定 文本 的 对 齐 方式 


<marquee align="middle> 我 在 中 间 </marquee> 


bgcolor 


颜色 值 "#000000" 


滚动 栏 的 颜色 


</marquee> 


<marquee bgcolor="#DEEBEF"> 看 到 了 吗 ? 


height 


| 数值 10.20.30… 


滚动 栏 高 度 


<marquee height="15"> 不 要 ， 太 矮 了 </marquee> 


width 


数值 10,20,30… 


滚动 栏 宽度 


3. <marquee> 标 签 的 其 他 属性 
除了 以 上 的 常规 设置 ，<marquee> 标 签 还 有 两 个 特殊 的 属性 ， 即 start0 和 stop0， 它 们 可 以 配合 
JavaScript 事件 产生 很 有 意思 的 效果 。 例 如 : 


<marquee width="100"> 哇 ! 好 大 的 房子 啊 < marquee> 
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onMouseOut="this start()": // 当 鼠标 移出 该 区 域 时 ， 开 始 滚动 
‘onMouseOver="this.stop()"; // 当 鼠标 进入 该 区 域 时 ， 停 止 滚动 


8.5.3 首页 的 实现 过 程 


博客 管理 系统 采用 二 分 栏 结构 ， 表 单 布局 。 具 体 实现 代码 如 下 : 
例 程 01 ”代码 位 置 ， 光盘 \TM\08\tmlog\index.php 


<?php 

session_start(); // 开 启 session 支 持 
include "Conn/conn.php"; // 包 含 数据 库 链 接 文件 
> 


<table width="757" border="0" align="center" cellpadding="0" cellspacing="0"> 

<tr align="right" valign="top"> 

Sy height="149" colspan="2" background="images/head.jpg"> 

<! -上 部 导航 栏 一 > 

</td> 
</tr> 
<tr> 

a width="236" height="501" me images/left.jpg"> 

一 左 侧 导航 栏 --> 
</td> 
<td width="521" height="501" align="center" background=" images/right.jpg"> 


S$p_sql = "select * from tb_public order by id dese"; // 从 数据 表 中 读 取 数 据 
$p_rst = mysql_query($p_sql,S$link); /执行 SQL 语句 
> 
< 一 <marquee> 标 签 开始 -一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 > 
0 <marquee onMouseOver=this.stop() style="WIDTH: 426px: HEIGHT: 280px" onMouseOut=this.start0 
scrollamount=2 scrolldelay=7 direction=up> 
<?php 
while($p_row = mysql_fetch_row(S$p_rst){ /循环 输出 公告 标题 
2> 
© <a href="#" onclick="wopen=open('show_pub.php?id=<?php echo 
$p row[0]; ?>",",height=200,width=500,scollbars=no")"><?php echo Sp_row[1]; ?></a><br> 
< 人 
</marquee> 
<<! 一 -一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 -- 一 - -> 


</td> 
</t> 
</table> 


Ah 代码 贴 二 

@ <marquee> 标 签 : <marquee> 标 签 中 包含 了 start 和 stop 两 个 特殊 的 属性 ， 还 有 速度 属性 scollamount 和 延迟 属性 
scrolldelay， 而 公告 栏 的 高 度 ( height ) 和 宽度 (width ) 则 是 通过 css 样式 设置 的 。 

@ <?php echo $p_row[1]; ?>: 循环 输出 公告 标题 ， 并 为 每 个 公告 添加 超 链 接 ， 这 里 用 到 了 JavaScript 脚本 的 open 
方法 ， 该 方法 的 作用 是 打开 一 个 新 窗口 ， 同时 可 以 对 窗口 样式 做 出 设置 。 Open 方法 的 一 般 格式 为 open(" 链 接 的 url"," 


自 定义 名 称 "," 窗 口 样式 ")。 
Sa 
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8.6 ”文章 管理 模块 设计 


8.6.1 文章 管理 模块 概述 


对 一 个 博客 系统 来 说 ， 文 章 管理 是 最 基本 的 功能 ， 但 同时 也 是 最 复杂 的 一 个 功能 。 本 系统 的 文章 
管理 模块 包括 “添加 博客 文章 ”、“ 查 找 博 客 文章 ”、“ 管 理 我 的 博客 ”、“ 发 表 评论 ” “删除 文章 ” 
和 “删除 评论 ”等 6 大 功能 。 其 中 ， 普 通用 户 只 能 删除 自己 的 文章 及 对 文章 的 评论 ， 只 有 管理 员 才 有 
权 删 除 任何 一 篇 文章 及 回复 。 下 面 给 出 文章 管理 模块 的 框架 ， 如 图 8.20 所 示 。 


图 8.20 文章 管理 模块 框架 图 


8.6.2 文章 管理 模块 技术 分 析 


想 要 使 用 文章 管理 模块 ， 前 提 是 用 户 必须 登录 ， 匿 名 用 户 是 无 法 访问 这 些 功 能 的 ， 想 要 删除 文章 
和 评论 ， 前 提 是 当前 用 户 要 么 是 管理 员 权 限 ， 要 么 是 文章 拥有 者 ， 奉 则 不 会 显示 删除 功能 的 。 这 两 方 
面 的 控制 都 需要 session 的 配合 ， 本 节 就 来 讲 一 下 session 的 应 用 及 常见 的 问题 处 理 。 

session 的 中 文 译名 为 “会 话 ”， 是 指 用 户 从 进入 网 站 开始 ， 直 到 关闭 网 站 这 段 时 间 内 ， 所 有 网 页 
共同 使 用 的 公共 变量 的 存 贮 机 制 。session 比 cookie 更 有 优势 : session 是 存储 在 服务 器 端的 ， 不 易 被 伪 
造 ，session 的 存储 没有 长 度 限 制 ; session 的 控制 更 容易 等 。 

PHP 中 的 session 功能 一 直 令 许多 初学 者 望 而 生 且 ， 因 为 经 常 出 现 一 些 莫名 其 妙 的 错误 ， 而 又 不 知 
道 如 何 去 解 决 。 其 实 ， 大 多 数 的 错误 都 是 因为 对 session 的 配置 不 了 解 而 使 用 方法 不 正确 造成 的 ， 在 


php.ini 中 对 session 的 配置 如 表 8.3 所 示 。 
*。385。 g 
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表 8.3 session 的 常用 配置 选项 


配置 选项 说 阴 
session.save_path = c¢:/temp 保存 session 变 量 的 目录 ， 在 linux/unix 下 为 /tmp 
session.ues_cookies= 1 是 否 使 用 cookie 
session.name = PHPSESSID 表示 会 话 ID 
session.auto start = 0 是 否 自动 启用 Session， 当 为 1 时 ， 在 每 页 中 就 不 必 调 用 Session_satrt() 函 数 了 
session.cookie_lifetime =0 设 定 cookie 送 到 浏览 器 后 的 保存 时 间 ， 单 位 为 秒 。 默 认 值 为 0， 表 示 直 到 浏览 器 关闭 
Session.cookie_path =/ cookie 有 效 路 径 
Session.cookie domain = 有 效 域名 
Session serialize handler= php “| 定义 序列 化 数据 的 标识 ， 本 功能 只 有 WDDX 模 块 或 PHP 内 部 使 用 ， 默 认 值 为 PHP 
session.gc_probability = 1 设 定 每 次 临时 文件 开始 处 理 的 处 理 概率 。 默 认 值 为 1 
session.gc_maxlifetime = 1440 “| 设 定 保存 Session 的 临时 文件 被 清除 前 的 存活 秒 数 
ne 决定 参照 到 客户 端的 Session 代 码 是 否 要 删除 。 有 时 出 于 安全 或 其 他 考虑 ， 会 设 定 不 
一 删除 。 默 认 值 为 0 
session.cache limiter= nocache | 设 定 Session 缓 冲 限制 
session.cache_expire 三 180 文档 有 效 期 ， 单 位 为 分 钟 
session.save_handler = files 用 于 保存 Session 变 量 ， 默 认 情况 下 用 文件 


对 于 初学 者 来 说 ，session 在 php.ini 中 是 不 需要 特意 去 改动 ， 因 为 安装 时 会 根据 操作 系统 自行 做 出 
适当 的 调整 。 只 在 少数 的 几 项 ， 如 session 存活 周期 (session.cookie_lifetime = 0) 、 自 动 开 启 session 
(session.auto_start) 等 稍 加 改动 即 可 。 
PHP 主要 是 通过 会 话 (session) 处 理 函 数 来 对 session 进行 控制 和 使 用 的 。 常 用 的 处 理 函 数 如 表 8.4 
所 示 。 
表 8.4 “PHP 常用 的 会 话 处 理 函数 


函数 函数 说 明 
session_start(); 开启 session 或 返回 已 经 存在 的 session 
$_SESSION['name'] = value; | 注册 一 个 session 变 量 
Session id() 设 定 或 取得 当前 的 session_id 值 


检测 指定 的 session 值 是 否 存在 。isset 不 只 可 以 检测 session， 还 可 以 检测 其 他 类 型 ， 如 


RON 二 isset($_ POST[name'])、isset($_GET[mame]) 等 


session_regenerate_id() 更 改 session_id 的 值 
session_name() 返回 或 改变 当前 session 的 name 
unset($ SESSION['name']) 删除 名 为 name 的 session。 注 意 
session destroy() 结束 当前 会 话 ， 删 除 所 有 session 


全 注意 : (1) 如 果 要 改变 当前 session 的 name 值 ， 必 须 在 session() 之 前 调用 session_name() 函 数 ， 而 
且 session_name 不 能 全 部 是 数字 ， 否 则 会 不 停 的 生成 新 的 session_id。 
(2) 不 可 以 写成 unset($_ SESSION)， 这 样 会 禁止 整个 会 话 的 功能 。 
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在 本 节 最 后 ， 介 绍 儿 个 使 用 session 时 要 注意 的 问题 。 

1. 尽 可 能 地 将 session_start 放 到 第 1 行 

这 种 情况 是 新 手 最 容易 犯 的 错误 。 产 生 的 错误 代码 为 : 

Waming: session_start() [function.session-start]: Cannot send session cache limiter - headers already sent… 

其 原因 就 是 在 使 用 session_start0) 之 前 ， 就 有 HTML 代码 输出 了 。 也 许 有 的 读者 会 说 : “没有 ， 
session_start 之 前 没有 任何 代码 ， 绝 对 没有 。” 那 么 ， 请 检查 你 的 程序 ， 是 不 是 有 空 行 ， 或 类 似 echo 
语句 的 输出 。 如 果 有 ， 请 去 掉 ， 因 为 就 算是 一 个 小 小 的 空格 都 是 不 可 以 的 。 所 以 ， 为 了 避免 这 类 错误 
的 发 生 ， 尽 可 能 地 将 session_start 放 到 第 1 行 。 

2. 在 使 用 session 之 前 一 定 要 先 写 session_start() 

大 多 数 读者 在 使 用 session 之 前 都 能 先 调用 session_start() 函 数 , 但 对 于 session_destroy() 函 数 却 经 常 
忽略 。session_destroy() 虽 然 是 结束 当前 会 话 并 删除 所 有 session， 但 在 删除 之 前 ， 也 要 先 开启 session 支 
持 才 可 以 ， 不 然 会 产生 这 样 的 错误 代码 : 

session_destroy() [function.session-destroy]: Trying to destroy uninitialized session in… 

所 以 ， 凡 是 在 使 用 session 或 session 函数 的 页 面 中 ， 都 要 加 上 session_start() 这 句 话 。 

3. 删除 所 有 session 

如 果 想 删除 所 有 session, 但 又 不 想 结束 当前 会 话 ， 用 unset 一 个 一 个 删除 实在 是 太 麻烦 了 ， 最 简单 
的 办 法 就 是 将 一 个 空 数组 赋 给 $_SESSION， 如 $_SESSION = array()， 这 样 就 解决 了 。 


8.6.3 添加 文章 的 实现 过 程 


国 ”添加 文章 模块 使 用 的 数据 表 : tb_article 
当 用 户 登录 后 ， 系 统 会 直接 进入 到 文章 添加 页 〈file.php) ， 也 可 以 通过 单 击 “文章 管理 ”/“ 添 加 


博客 文章 ” 


回 到 file.php 页 。 文 章 添加 页 面 的 运行 结果 如 图 8.21 所 示 。 
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欢迎 悠 : spcn 博客 首页 文章 管理 图 片 管理 朋友 图 管理 退出 登录 


| 添加 博客 文章 
博客 主题 : [全 天 中 于 要 按 削 了 
XEE: B|Z| UF [FF] Fs [| me [mR] 
《Eont sire=4 color= 和 000099) 中 午 吃 豆芽 我 不 要 吃 季 。 5 
文章 内 容 : 


EE 
图 8.21 添加 文章 页 面 的 运行 结果 
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添加 文章 页 为 一 个 发 布 表 单 ， 包 括 文章 主题 、 文 字 编辑 、 文 章 内容 等 元 素 。 部 分 表单 元 素 如 表 8.5 


所 示 。 
表 8.5 添加 文章 页 面 的 主要 表单 元 素 

名 称 | 元 素 类 型 重要 属性 含义 

myform form method="post" action="check file.php” 添加 文章 表单 

txt_title text id="txt title" size="68" 文章 标题 

i le name="font" 本 本 文章 字体 
onChange="showfont(this.options[this.selectedIndex].value)” 
class="wenbenkuang" 

size select 下 字体 大 小 
onChange="showsize(this.options[this.selectedIndex].value)" 

oi Select onchange "showeolortthis,optionslihis.ecleotedindexl value) 字体 颜色 
name="color" size="1" class="wenbenkuang" id="select" 

file textarea cols="75" rows="20" id="file" style="border: Opx; width:520px;" 文章 内 容 

btn 1 submit id="btn_tj" value=" 提 交 " onClick="retum check(;" “提交 ”按钮 


进行 处 理 。 在 处 理 页 中 ,将 传 过 来 的 文章 标题 、 文 章 作者 和 文章 内 容 等 
存 到 数据 表 中 。 如 果 添 加 信 
到 上 


当 用 户 填 写 完 博客 主题 和 文章 内 容 后 ， 单 击 “ 提 交 ” 按 钮 ， 系 统 将 跳 转 到 处 理 页 (check_file.php) 
参数 组 成 insert 语句 ， 并 最 终 保 
成 功 ， 系 统 返回 到 本 页 ， 可 继续 执行 添加 操作 ;如 果 添 加 失败 ， 则 返回 
一 步 。 程 序 的 关键 代码 如 下 : 

例 程 02 ”代码 位 置 ， 光盘 \TM\08\tmlog\check_file.php 


<?php 

session_start(); /开启 session 支 持 

include "Conn/conn.php"; /包含 数据 库 链接 文件 
if($btn ti"){ 1/ 判断 传 值 页 面 
Stitle=$_POST[txt_title]; // 取 得 文章 标题 
$author=$_SESSION[usemame]; /取得 作者 
S$content=$_POSTT[file]; // 取 得 文章 内 容 
$now=date("Y-m-d H:i:s"); /使 用 date 函 数 生成 发 布 时间 


族 生成 insert 语 名 */ 
$sql="Insert Into tb article (title,content,author,now) Values ('S$title','$content','$author','$now")"; 
$result=mysql_query($sq]l); // 执 行 insert 语 句 
诈 根据 Sresult， 返 回 结果 */ 
if($result){ 
echo "<script>alert(' 燕 喜 您 ， 你 的 文章 发 表 成 功 !11");window .location.href='file.php';</script>"; 
1 
elsef 
echo "<script>alert(' 对 不 起 ， 添 加 操作 失败 !1!");history.go(-1);</script>"; 
b; 
jelsef 
echo "<script>alert(' 对 不 起 ， 添 加 操作 失败 !11);history.go(-1);</script>"; 
b 
> 
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[DO 说 明 : 文章 添加 页 面 中 ， 使 用 了 部 分 UBB 语法 ， 由 于 UBB 语法 不 属于 本 书 的 范畴 ， 所 以 这 里 不 
做 讲解 ， 请 感 兴趣 的 朋友 查看 相关 的 书籍。 


8.6.4 文章 列表 的 实现 过 程 


国 查看 文章 列表 使 用 的 数据 表 : tb_article 
单 击 “ 文 章 管理 ”/“ 我 的 文章 ”， 将 显示 用 户 发 表 过 的 文章 列表 。 文 章 列表 页 面 (myfiles.php) 
的 运行 结果 如 图 8.22 所 示 。 


DO 
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欢迎 您 ; spcn 博客 首页 文章 管理 图 片 管理 朋友 图 管理 退出 登录 
| 查看 我 的 文章 | 
二 今天 中 午 要 欣 壤 了 ~ 
页 次 : 1/1 页 记录 : 1 条 
图 8.22 文章 列表 页 面 的 运行 结果 
文章 列表 页 面 使 用 了 分 页 技术 和 do...while 循环 语句 来 输出 文章 标题 。 程 序 关 键 代码 如 下 : 
例 程 03 ”代码 位 置 ， 光 盘 \TM\08\tmlog\myfiles.php 


<?php 

session_start(); // 开 启 session 支 持 

include "Conn/conn.php"; // 包 含 数据 库 链 接 文件 

include "check_login.php"; // 包 含 权 限 检查 文件 

> 

万 分 页 

<?php 

族 ”Spage 为 当前 页 ， 如 果 Spage 为 空 ， 则 初始 化 为 ! */ 

if (S$page==""){ 
Spage=1;} 

© if(is numeric(Spage){ 
S$page_size=20; /| 每 页 显示 20 条 记录 
$query="select count(*) as total from tb article where author=".$ SESSION[username]." order by id desc"; 
Sresult=mysql_query($query); // 查 询 符合 条 件 的 记录 总 条 数 
$message_count=mysql_result($resulb0,"total"); // 要 显示 的 总 记录 数 
S$page_count=ceil($message_count/$page_size); // 根 据 记录 总 数 除 以 每 页 显示 的 记录 数 求 出 所 分 的 页 数 
S$offset=($page-1)*$page_size; /计算 下 一 页 从 第 几 条 数据 开始 循环 
$sql=mysql query("select id,title from tb article where author = ".$ SESSION[usemame]." order by id desc limit 
S$offset, $page_size"); 

S$info=mysql fetch array($sql); 

> 

<?php 
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睛 输出 结果 集 */ 
if($info){ 
$i=1; // 文 章 序号 
© dof /do.while 循 环 开始 
?> 
<tr> 


<!-- ”显示 文章 序号 和 文章 标题 -> 

<td width="498" align="left" valign="top"> &nbsp;&nbsp;&nbsp;<a href="showmy.php?file id=<?php echo 
$info[id];2>"><?php echo $i."、".Sinfo[title]:?></a> </td> 

</tr> 

<?php 

$i=$i+1; 

}while(Sinfo=mysql_fetch_array(SsqD) // 循 环 结束 

?> 

</table></td> 

</tr> 

</table></td> 

</tr> 

?php } 7> 


<!--” 翻 页 条 --> 

<td width="33%">&nbsp;&nbsp; 页 次 : <?php echo Spage;?>/<?php echo Spage_count;?> 页 &nbsp; 记 录 : <?php echo 
Smessage_count;?> 条 &nbsp; </td> 

<td width="67%" align="right" class="hongse01"> 

<?php 

上 # ”如果 当 前 页 不 是 首页 */ 

if($page!=1){ 

履 显示 “首页 ” 超 链 接 */ 

echo "<a href=myfiles.php?page=1> 首 页 </a>&nbsp;"; 

族 显示 “上 一 页 ” 超 链接 */ 

echo "<a href=myfiles.php?page=".($page-1)."> 上 一 页 </a>&nbsp;"; 


} 

族 ”如果 当前 页 不 是 尾 页 */ 

if($page<$page_count) 

{ 

族 显示 “下 一 页 ” 超 链 接 */ 

echo "<a href=myfiles.php?page=".($page+1)."> 下 一 页 </a>&nbsp;"; 

证 显示 “ 尾 页 ” 超 链接 */ 

echo "<ahref=myfiles.php?page=".$page_count."> 尾 页 </a>"; 

全 

?> 
< 代码 贴 二 

@ is_numeric($page): is_numeric() 函 数 判 断 变 量 Spage 是 否 为 数字 ， 如 果 是 数字 ， 则 返回 true， 否 者 返回 false。 如 
果 一 组 字符 全 部 由 数字 组 成 ， 那 么 is_numeric() 函 数 也 将 返回 true。 

四 do.…while() 循 环 和 while() 循 环 : do...while0 循 环 是 先 执 行 {} 中 的 代码 段 ， 然后 判断 while 中 的 条 件 表达 式 是 否 成 
立 ， 如 果 成 立 返 回 ture， 则 重复 输出 {} 中 的 内 容 ， 否 则 结束 循环 ,执行 while 下 面 的 语句 。While 循环 是 先 判断 while 中 
的 表达 式 ， 当 返回 ture 时 ， 再 执行 f} 中 的 代码 。 两 者 的 区 别 是 : do..while() 循 环比 while() 循 环 多 输出 1 次 结果 。 
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8.6.5 查看 文章 、 评 论 的 实现 过 程 
国 ”查看 文章 、 评 论 使 用 的 数据 表 : tb_article、tb_filecomment 


单 击 列表 中 任意 一 个 文章 标题 , 都 会 看 到 对 应 的 文章 内 容 和 文章 评论 。 查 看 文章 页 面 (showmy.php) 
的 运行 结果 如 图 8.23 所 示 。 


[ Sm WOM 


RE 
| | 博客 文章 | 


32007 -12-10 
博客 ID 号 55 作者 spon 发 表 时 间 13:22:51 
博客 主题 ”今天 中 午 要 找 错 了 ~ 
中 午 吃 豆芽 ， 我 不 爱 吃 啊 


文章 内 容 
| 55555555555555555555555 ”到 了 


| 国 ee _ 
评论 ID 号 88 ”评论 人 q3939 评论 时 间 2007-12-19 13;24:59 
评论 内 容 这 就 是 偏食 的 结果 ，HOHO~~ ^D~^ XX 删除 

页 次 : 1/1 页 记录 : 1 条 


[| 


我 要 评论 


轩 yl WE 
图 8.23 查看 文章 页 面 的 运行 结果 


系统 根据 当前 页 面 传 过 来 的 文章 id 值 从 数据 表 tb_article 中 返回 对 应 的 文章 信息 (包括 文章 id、 文 
章 作者 、 文 章 标题 、 文 章 内 容 和 发 表 时 间 ) 、 输 出 文章 信息 后 ， 开 始 查找 表 tb_filecomment 中 fileid 字 
段 值 等 于 文章 id 的 所 有 评论 集 ， 并 通过 分 页 显示 出 来 。 显 示 文 章 页 面 (showmy.php) 的 关键 代码 如 下 : 
例 程 04 ”代码 位 置 : 光盘 \TM\08\tmlog\showmy.php 


<?php 

session_start(); // 开 启 session 支 持 

include "Conn/conn.php"; // 包 含 数据 库 链 接 文件 

include "check_login.php"; // 包 含 权 限 检查 文件 

Sfile idl=$ GET[file id]; // 取 得 文章 ID 号 

$bool = false; // 判 断 用 户 删除 权限 ,默认 的 false 是 没有 权限 


1. 
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7> 
<!- 首部 导航 栏 -> 
二 二 
<!-- 文章 显示 区 -> 
<?php 
$sql=mysql_query("select * from tb_article where id =".$file_id1); /根据 文章 ID 号 查找 文章 
$result=mysql_fetch_array($sql); /返回 结果 集 
人 > 
到 一- 显示 文章 -一 -一 一 一 一 一 一 一 一 一 一 一 一 > 


table width="100%" border="1" cellpadding="1" cellspacing="1" bordercolor="#D6E7AS" bgcolor="#FFFFFF" 
class="i table"> 
<tr bgcolor="#FFFFFF"> 

<td width="14%" align="center"> 博 客 ID 号 </td> 


<td width="15%"><?php echo Sresult[id]; ?></td> 
<td width="11%" align="center"> 作 者 </td> 


一 全 > 
8%"><2?php echo $result[author]; ?></td> 
2%" align="center"> 发 表 时 间 </td> 
下 下 用 > 


="30%"><?php echo Sresult[now]; ?></td> 
</tr> <tr bgcolor="#FFFFFF"> 
<td align="center"> 博 客 主题 </td> 


<td colspan="5">&nbsp;&nbsp;<?php echo Sresultltitle]; 人 < 由 
</tr> <tr bgcolor="#FFFFFF"> 
<td align="center"> 文 章 内 容 </td> 


<2php 
履 判断 登录 用 户 是 否 为 管理 员 ， 或 者 是 文章 的 作者 3/ 
if($ SESSION[fig]==1 or ($ SESSION[username] 一 Sresult[author]))f 
语 如 果 是 ， 就 将 Sbool 设 为 true */ 
$bool = 
> 
< 同时 显示 “删除 ”按钮 ， 并 将 文章 4 作为 tl 后 组 一 起 传 到 处 理 页 - > 


<a href="del file.php?file id=<?php echo $result[id]:?>"><img src="images/A delete.gif' width="52" height="16" alt=" 
删除 博客 文章 " onClick="return d_chk();"></a> 
<?php } ?> 
<?php 
// 分 页 代码 部 分 略 
$sql=mysql_query("select * from tb_filecomment where fileid="$file_id1' order by id desc limit $offset, $page_size"); 
$result=mysql fetch array($sql); 
/站 六 来 当 六 六 素 六 六 六 六 六 六 六 六 六 六 夺 玉 率 术 太太 亲 术 本 不 本 根 据 返 回 记录 集 输 出 记录 * 玉 下 下 六 下 玉 玉 六 六 来 六 六 六 六 六 六 六 六 率 闵 六 六 闪闪 六 率 素 六 来 六 六 来/ 
if($result==false){ 
echo "<font color=#f0000> 对 不 起 ， 没 有 相关 评论 !</font>"; 
}else{ 
dof 
‘> 
<t> 
<td height="57" align="center" valign="top" ><table width="480" border="1" cellpadding="1" 
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cellspacing="1" bordercolor="#D6E7AS" bgcolor="#FFFFFF" class="i table"> 


<tr bgcolor="#FFFFFF"> 
<td width="14%" align="center"> 评 论 ID 号 </td> 
2 评论 这 -一 一 -一 -一 一 一 一- 一 一 > 


<td width="15%"><?php echo Sresult[id]; ?></td> 
<td width="11%" align="center"> 评 论 人 </td> 
< 评论 人 -一 一 一 一 一 一 一 一 一 一 一 一 - -- > 
<td width="18%"><?php echo Sresult[username]; ?></td> 
<td width="12%" align="center"> 评 论 时 间 </td> 
二 二 评论 时 间 - 一 一 一- -- > 
<td width="30%"><?php echo Sresult[datetime]; ?></td> 
</t> 
<tr bgcolor="#FFFFFF"> 
<td align="center"> 评 论 内 容 </td> 
内 和 > 


‘4"><?php echo Sresult[content]; ?></td> 


<?php 

上 # 如 果 Sbool 为 真 ， 输 出 删除 超 链 接 ， 否 则 跳 过 */ 
if ($booD{ 
和 


<a href="del_comment.php?comment_id=<?php echo $result[id]?>"><img src="images/A_delete.gif" width="52" 
height="16" alt=" 删 除 博客 文章 评论 " onClick="retum d_chk0:"></a> 
<?php } ?> 
</td></tr> </table></td> <t> 
<?php 
}while($result=mysql fetch array($sq]l)); 


b 
> 


</table> 
- <!-。 翻 页 功能 代码 部 分 咯 -> 


8.6.6 删除 文章 、 评 论 的 实现 过 程 


国 查看 文章 、 评 论 模块 使 用 的 数据 表 : tb_article、tb_filecomment 

在 查看 文章 评论 页 面 ， 当 系统 判定 当前 用 户 为 管理 员 或 是 文章 作者 时 ， 在 每 篇 文章 和 评论 的 后 面 ， 
都 将 显示 相应 的 “删除 ”按钮 。 单 击 任意 的 “删除 ”按钮 ， 系 统 会 提示 是 否 删除 ， 如 果 确 认 ， 将 跳 转 
到 处 理 页 (del_file.php 和 del_commentphp) ， 完 成 删除 操作 。 

在 删除 文章 的 处 理 页 中 ， 删 除 文章 的 同时 ， 也 删除 了 该 篇 文章 的 相关 的 评论 。 处 理 页 首先 在 文章 
列表 (tb_article) 中 删除 id 等 于 $file_id 的 记录 ， 如 果 没 有 可 删除 记录 ， 则 提示 失败 ， 并 返回 上 一 步 ; 
如 果 删 除 成 功 ， 则 转 到 评论 列表 (tb_filecomment) 中 ， 删除 所 有 该 篇 文章 的 评论 。 删 除 文章 页 
(Cdel_file.php) 的 关键 代码 如 下 : 


例 程 05 ”代码 位 置 : 光盘 \TM\08\tmlog\del_file.php 


<2php 
session _start(); /开启 session 支 持 
include "check_login.php"; // 包 含 权 限 检查 文件 
include "Conn/conn.php"; // 包 含 数据 库 链接 文件 
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$sql="delete from tb_article where id=".$file_id; /1/ 删 除 文章 的 delete 语 句 
Sresult=mysql_query($sql,$link); // 执 行 删除 操作 
if($result){ 
$sqll = "delete from tb_filecomment where fileid = ".Sfile id; /删除 相对 应 的 文章 评论 
Srstl = mysql_ query($sqll,3linko); /执行 删除 评论 的 操作 
if($rst1) 
echo "<script>alert(' 博 客 文章 已 被 删除 !");location="myfiles.php]';</script>"; 
else 
echo "<script>alert(' 删 除 失败 !");history.go(-1);</script>"; 
} 
elsef 
echo "<script>alert(' 博 客 文章 删除 操作 失败 !");history.go(-1);</script>"; 
} 
> 


因为 删除 文章 的 过 程 也 包含 了 删除 评论 的 过 程 ， 所 以 这 里 就 不 给 出 删除 评论 的 代码 了 。 
8.7 ”图 片上 传 模块 设计 


由 于 动态 网 络 编程 技术 的 诞生 ， 使 得 网 络 更 加 入 性 化 ， 为 了 能 够 和 用 户 更 好 地 互动 ， 很 多 网 站 都 
提供 了 让 用 户 上 传 图 片 的 功能 。 一 个 网 站 拥有 图 片上 传 功能 是 非常 必要 的 。 


8.7.1 图 片上 传 模块 概述 
图 片上 传 在 动态 网 页 开发 过 程 中 应 用 非常 广泛 。 如 果 有 比较 好 的 图 片 想 和 其 他 人 一 同 分 享 ， 就 可 以 


通过 图 片上 传 功能 来 实现 ， 以 增加 网 站 的 核心 竞争 力 。 本 系统 的 图 片上 传 模块 主要 实现 对 图 片 的 添加 、 
浏览 、 查 询 和 删除 操作 ， 而 对 图 片 的 删除 则 只 有 管理 员 才 有 权限 。 图 片上 传 模块 框架 图 如 图 8.24 所 示 。 


图 8.24 图 片上 传 模块 框架 图 


Sa 
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8.7.2 图 片上 传 模块 技术 分 析 


既然 是 图 片上 传 模块 ， 显 而 易 见 本 节 的 主要 技术 就 是 上 传 图 片 功能 了 。 上 传 图 片 和 上 传 文件 的 原 
理 基本 相同 ， 下 面 就 来 一 步 一 步 地 学 习 如 何 上 传 图 片 和 图 片 的 两 种 保存 方式 。 
1. 上 传 图 片 的 基本 流程 
在 网 页 中 实现 上 传 图 片 功能 的 步骤 如 下 : 
(1) 通过 <form> 表 单 中 的 file 元 素 选 取 上 传 数据 。 
使 用 file 元 素 上 传 数据 时 注意 一 点 : 就 是 在 form 表单 中 要 加 上 属性 enctype="multipart/form-data"， 
否则 上 传 不 了 文件 〈 图 片 ) 。 
(2) 在 处 理 页 中 使 用 $_FILES 变量 中 的 属性 判断 上 传 文件 类 型 和 上 传 文件 (图 片 ) 大 小 是 否 符合 
$_FILES 变量 为 系统 预定 义 变量 ， 保 存 的 是 上 传 文件 (图片) 的 相关 属性 。 使 用 格式 为 : 
$_FILES[name][property]; 


图 片 的 相关 属性 如 表 8.6 所 示 。 
表 8.6 $_FILES 的 相关 属性 

属 性 值 说 明 
name 上 传 文件 的 文件 名 

pe 上 传 文件 的 类 型 
size 上 传 文件 的 大 小 
tmp_ name 上 传 文件 在 服务 器 中 的 临时 文件 名 
error 上 传 文件 失败 的 错误 代码 


(3) 使 用 move_uploaded_file() 函数 上 传 文件 (图片) 或 将 文件 (图片) 以 二 进 制 的 形式 保存 到 
数据 库 中 。 

使 用 函数 将 文件 (图片 ) 保存 到 对 应 的 文件 夹 中 和 以 二 进 制 的 形式 保存 到 数据 库 中 是 上 传 文件 (图 
片 ) 的 两 种 形式 ， 稍 后 将 单独 做 介绍 。 

(4) 返回 页 面 等 待 下 一 步 操作 。 

2. 使 用 上 传 函数 保存 文件 〈 图 片 ) 

使 用 上 传 函 数 上 传 文件 〈 图 片 ) 的 本 质 就 是 将 文件 〈 图 片 ) 从 浏览 器 端 复制 到 服务 器 端 指定 的 文 
件 夹 里 ， 数 据 库 所 存储 的 就 是 文件 〈 图 片 ) 的 相对 地 址 。 当 页 面 显 示 图 片 时 ， 实 际 是 分 两 步 : 第 一 步 
是 读 取 数据 表 中 的 地 址 ， 第 二 步 是 根据 地 址 找到 并 在 页 面 中 显示 图 片 。 使 用 目录 保存 文件 的 好 处 是 减 
少 了 数据 库 的 容量 和 对 数据 库 的 压力 ， 而 且 图 片 很 容易 被 搜索 引擎 抓 到 ， 从 而 提高 网 站 流量 和 人 气 。 


move_uploaded_file() 函 数 的 一 般 格式 为 : 
*。395。 乡 


bool move_uploaded file ( string filename, string destination ); 


filename: 上 传 到 服务 器 中 的 临时 文件 名 。 
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destination: 保存 文件 的 实际 路 径 。 


各 注意 : 这 里 的 filename 为 临时 文件 名 ， 而 不 是 上 传 文件 的 原文 件 名 ， 可 以 通过 $_FILES[filename] 
[tmp_name] 来 获取 。 


下 面 看 一 个 实例 ， 程 序 代码 如 下 : 


<label> 请 选择 要 上 传 的 图 片 〈 文 件 小 于 500K) : </label> 

<!-- 上 传 文件 的 form 表 单 --> 

<form method="post" action="#" enctype="multipart/form-data"> 
<input type="hidden" name="action" value="upload" /> 
<input type="file" name="u file"/> 
<input type="submit" value=" 上 传 " /> 


</form> 
Ne > 
<?php 
必 判断 是 否 为 上 传动 作 */ 
iflisset($ POST[action]))f 
Sfile_path ="./"; // 上 传 文件 存放 路 径 ，./ 为 当前 目录 下 
S$profix = array("jpg",".gif"," .jpeg"); /设置 允许 上 传 的 文件 后 组 类 型 
S$f name=$_FILES[u_file][name]; // 取 得 要 上 传 的 文件 名 
$pro_name=substr($f_name,strrpos($f_name,".")); // 取 得 上 传 文件 的 后 缀 
if(!in_array($pro_name, $profix){ /判断 上 传 文件 的 类 型 是 否 为 允许 类 型 
echo "文件 格式 不 对 "; 
exit(); 
} 
if($_FILES[u_file][size] <= 0){ /判断 上 传 文件 的 大 小 


echo "文件 上 传 错误 ， 或 文件 大 于 500K, 请 重新 上 传 "， ”// 如 果 文 件 过 大 ， 提 示 错 误 
b 


elsef 
上 # 上 传 文件 函数 */ 
move uploaded file($ FILES[u filel[tmp namel,Sfile path.$ FILES[u filel[name]); 
echo "上 传 成 功 !"; 

上 


> 

3. 使 用 二 进 制 保存 图 片 

上 传 图 片 的 另 一 种 保存 方式 是 以 二 进 制 的 形式 存储 在 数据 库 中 。 在 计算 机 看 来 ， 再 美的 图 片 、 再 感人 
的 文章 ， 也 不 过 就 是 一 堆 “0111010011…” 的 代码 段 而 已 ， 和 其 他 数据 没有 什么 区 别 ， 存 到 数据 表 中 都 是 
一 样 的 。 存 储 图 片 不 再 需要 使 用 move_uploads_file(0) 函 数 ， 在 处 理 页 中 直接 使 用 二 进 制 的 形式 读 取出 文件 
图 片 ， 并 存 到 数据 表 中 。 本 系统 采用 的 就 是 二 进 制 的 形式 来 保存 图 片 ， 具 体操 作 将 在 实现 过 程 里 给 出 。 

使 用 二 进 制 来 保存 图 片 的 好 处 是 安全 ， 特 别 是 涉及 到 个 人 隐私 ， 不 易 被 窃取 ;存储 方便 ， 和 表 中 
其 他 数据 同等 操作 就 可 以 ;节省 磁盘 空间 ， 由 于 文件 系统 类 型 的 限制 ， 放 到 数据 表 中 的 数据 一 定 比 直 
接 放 到 磁盘 中 要 节省 空间 。 

当然 二 进 制 形式 的 图 片 也 有 很 大 束 端 ， 在 传 出 的 过 程 中 ， 如 果 某 个 二 进 制 位 出 现 丢 失 或 损坏 ， 那 
么 整 张 图 片 将 无 法 显示 ， 而 是 变 为 一 堆 乱码 ， 而 且 如 果 存 储 的 图 片 过 多 ， 造 成 数据 库 过 于 庞大 ， 影 响 
其 他 数据 的 正常 读 取 ， 增 大 服务 器 的 负担 。 所 以 ， 对 于 太 大 的 文件 ， 就 不 适宜 保存 到 数据 库 中 而 是 放 


到 文件 夹 。 
Re 
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8.7.3 图 片上 传 的 实现 过 程 


国 查看 文章 、 评 论 模块 使 用 的 数据 表 : tb tpsc 

博客 用 户 登录 后 ， 单 击 导航 栏 中 的 “图 片 管理 ”/“ 添 加 图 片 ” 选 项 ， 即 可 进入 添加 图 片 页 面 ， 在 
“图 片 名 称 ” 文 本 框 中 添加 上 传 的 图 片 名 称 ， 在 “上 传 路 径 ” 文 本 框 中 选择 或 者 单 击 “ 浏 览 ”按钮 选 
择 自 己 喜欢 的 图 片 ， 单 击 “ 提 交 ” 按 钮 ， 以 二 进 制 形式 将 图 片上 传 到 数据 库 中 。 图 片上 传 页 面 的 运行 
结果 如 图 8.25 所 示 。 


| 


HNCICUN Sm WWE 


欢迎 您 : spcn 博客 首页 文章 管理 图 片 管理 朋友 图 管理 退出 登录 


| 添加 图 片 | 
图 片 名 称 : [到 色 的 水 泡 
上 传略 径 : [E:\Docunents and Setting 目 区 宽 


EE 
图 8.25 图 片上 传 页 面 的 运行 结果 


图 片上 传 页 是 一 个 上 传 文件 的 表单 ， 主 要 包括 一 个 文本 域 、 一 个 文件 域 和 一 个 “提交 ”按钮 。 部 
分 表单 元 素 的 名 称 及 属性 如 表 8.7 所 示 。 


表 8.7 图 片上 传 页 面 中 的 表单 元 素 


="23" maxlength="60" 


当 用 户 输 入 图 片 名 称 , 并 选择 图 片 路 径 后 , 单 击 “ 提 交 ” 按 钮 , 系统 将 进入 到 上 传 处 理 页 (tptj_ok.php) 
中 进行 处 理 。 在 处 理 页 中 ， 首 先 对 图 片 名 称 进 行 处 理 ， 去 掉 特殊 字符 、 空 行 和 空格 ， 然 后 对 上 传 的 文 
件 进行 类 型 检查 、 文 件 大 小 检查 。 最 后 以 二 进 制 的 形式 ， 和 图 片 的 其 他 信息 〈 如 上 传 用 户 、 上 传 时 间 
等 ) 一 起 存 进 数据 表 中 。 关 键 代 码 如 下 : 

例 程 06 ”代码 位 置 : 光盘 \TM\08\tmlog\tptj_ok.php 


<?php 
“397。 g 
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session_start(); // 开 启 session 支 持 
include "check_login.php"; // 包 含 权 限 检查 文件 
include "Conn/conn.php"; // 包 含 数据 库 链 接 文件 
if($_POST["btn_1j"]==" 提 交 "){ 
© Stpmc=htmlspecialchars($tpmc); // 将 图 片 名 称 中 的 特殊 字符 转换 成 HTML 格 式 
@ S$tpmc=str_replace("m","<br>",Stpmc); /将 图 片 名 称 中 的 回 车 符 以 自动 换行 符 取代 
$tpmc=str replace("","&nbsp:",Stpmc); // 将 图 片 名 称 中 的 空格 以 "&nbsp;" 取 代 
$author=$ SESSION[usemame]l; 
S$scsj=date("Y-m-d"); // 设 置 图 片 的 上 传 时 间 
$profix = array("jpg",".gif"," jpeg"); // 设 置 允许 上 传 的 文件 后 缀 类 型 
Sf _ name =$_FILES[file][name]; // 取 得 要 上 传 的 文件 名 
$pro_name=substr($f_name,strrppos($f_name,".")); /取得 上 传 文件 的 后 组 
必 判断 上 传 文件 的 类 型 是 否 为 允许 类 型 */ 
© if(!in_array(strtolower($pro_name), $profix){ 
echo "<script>alert(' 文 件 格式 不 对 ');history.go(-1);</script>"; 
exit(); 
} 
履 判断 上 传 文件 的 大 小 ， 如 果 文 件 过 大 ， 提 示 错 误 */ 
if($_FILES[file][size] > 500000){ 
echo ee 请 重新 上 传 );history.go(-1)</script>"; 
exit(); 
; 
elsef 
S$fp=fopen(S$file,"r"); // 以 只 读 方式 打开 文件 
S$file=addslashes(fread($fp,filesize(Sfile))); /将 文件 中 的 引号 部 分 加 上 反 斜 线 
$query="insert into tb tpsc (tpmc,file,author'scsj) values ('$Stpmc',Sfile'$author,$scsj)"; 
$result=mysql_query($query); 
echo "<meta http-equiv=\"refresh\" content=\"1;url=browse_pic.php\"> 图 片上 传 成 功 ， 请 稍 等 .…"; 
} 
} 
> 
Ah 代码 贴 十 


@ htmlspecialchars() 函 数 : 将 特殊 字符 转换 成 HTML 格式 。 

@ str_replace() 函 数 : 取代 所 有 在 字 串 中 出 现 的 字 串 。 语 法 如 下 : 

mixed str_replace ( mixed search, mixed replace, mixed subject , int &count ) 

str_replace() 函 数 将 所 有 在 参数 subject 中 出 现 的 search 以 参数 replace 替换 ， 参 数 &count 表示 替换 字符 串 执行 的 次 
数 。 

目 strtolower: 将 字符 转换 为 小 写字 母 。 


8.7.4 图 片 浏览 的 实现 过 程 


国 图 片上 传 使 用 的 数据 表 : tb tpsc 

无 论 是 注册 用 户 ， 还 是 非 注册 用 户 ， 只 要 登录 网 站 ， 就 可 以 无 条 件 地 浏览 所 有 图 片 。 而 删除 图 片 
除了 管理 员 ， 其 他 人 都 无 权 操作 。 非 注册 用 户 可 以 通过 首页 中 的 “最 新 图 片 ” 进 入 图 片 浏览 页 面 ， 注 
册 用 户 先 进入 个 人 管理 界面 ， 单 击 “ 图 片 管 理 ”/“ 浏 览 图 片 ”菜单 ， 同 样 可 以 进入 图 片 浏览 页 面 。 注 
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册 用 户 浏览 图 片 页 面 的 运行 结果 ， 如 图 8.26 所 示 。 
N 


欢迎 您 ; spcn 博客 首页 文章 管理 图 片 管理 朋友 图 管理 退出 登录 


浏览 图 片 | 


BB 


上 全 间 ; 2007-12- 因 上 名称 河 妥 的 小 上 伟 时 间 :2007-12.14 


页 次 : 1/1 页 记录 : 2 条 
图 8.26 浏览 图 片 页 面 的 运行 结果 
本 页 的 实现 代码 和 查看 文章 页 面 略 有 不 同 ， 查 看 文章 页 面 中 ， 每 条 数据 占 了 一 行 ， 而 查看 图 片 则 
采用 的 是 分 栏 显 示 ， 以 每 行 两 张 图 片 的 格式 输出 ， 每 页 显示 4 张 图 片 。 通 过 单 击 小 图 片 ， 可 以 查看 图 
片 原 效果 图 。 程 序 关 键 代 码 如 下 : 
例 程 07 ”代码 位 置 ， 光盘 \TM\08\tmlog\browse_pic.php 


<?php 
session_start(); // 开 启 session 支 持 
include "Conn/conn.php"; // 包 含 数据 库 链 接 文件 
include "check_login.php": // 包 含 权 限 检查 文件 
Te 
时 <!-- 首 部 导航 栏 -> 
<tr align="left" colspan="2" > 
<td width="390" height="25" colspan="3" valign="top" bgcolor="#EFF7DE"> <span class="tableBorder_LTR"> 浏 
览 图 片 </span></td></tr> 
<tr> 
<td height="192" align="center" valign="top" > 
<?php 
区 // 分 页 显示 
$query="select * from tb_tpsc where scsj order by id desc limit $offset $page_size"; 
族 ”返回 结果 集 */ 
$result=mysql_query(Squery); 
> 


<table width="496" border="1" align="center" cellpadding="3" cellspacing="1" bordercolor="#D6D7D6"> 


0. 
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<tr> 


<?php 
设置 一 个 变量 ， 判 断 当前 数据 是 奇数 输出 还 是 偶数 输出 


并 


$i=1; 
while($info=mysql_fetch_array($result)) 
{ 
语 ” 如 果 当 前 为 偶数 输出 ， 记 录 输 出 完毕 后 结束 <tr> 标 签 、*/ 
这 $i%2 一 0){ 
?> 
<td width="500"><table width="245" border="0" cellpadding="0" cellspacing="0"> 


<tr> 
<td colspan="2"><div align="center"> 


<!-- 显 示 图 片 页 image.php --> 
<a hre="image.php?recid=<?php echo $infolid]; ?>" target=" blank"><img 
src="image.php?recid=<?php echo $info[id]:?>" width="150" height="100"></a></div></td></tr> 


<tr> 
<td width="109" height="25" align="left">&nbsp; 图 片 名 称 :<?php echo 


$info[tpmc];2></td> 
<td width="128"> 上传 时 间 :<?php echo $info[scsj];?></td></tr> 
<tr> 
<td colspan="2" height="25"> 


<?php 
人 # 如果 登录 用 户 为 管理 员 ， 显 示 删除 操作 


if($ SESSION[fig] 一 1){ 


a 


7> 
<a href="remove.php?pic id=<?php echo S$info[id]?>"><img 


src="images/A_delete.gif" width="52" height="16" alt=" 删 除 图 片 " onClick="return pic_chk0:"></a> 
<?php 


</tr> 
</table></td> 
</tr> 
<?php 


} 
族 否 者 ， 开 始 新 的 一 行 */ 
else 


{ 
> 


<td width="500" ><table width="236" border="0" cellpadding="0" cellspacing="0"> 
<t> 
<td colspan="2"><div align="center"><a href="image.php?recid=<?php echo $info[id]; ?>" 
target=" blank"><img src="image.php?recid=<?php echo $info[id];?>" width="150" height="100"></a></div></td> 


</t> 


<tr> 
="110" height="25">&nbsp; 图 片 名 称 :<?php echo Sinfo[tpme];?></td> 


<td wi 
<td width="126"> 上 传 时 间 :&nbsp;<?php echo Sinfo[scsj];?></td> 


</t> 
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<tr> 
<td colspan="2" height="25"> 
<2php 
if ($_SESSIONI[fig]==D{ 
> 
<a href="remove.php?pic id=<?php echo $info[id]?>"><img 
src="images/A_delete.gif" width="52" height="16" alt=" 删 除 图 片 " onClick="return pic_chk();"></a> 


<2php 
} 
> 
</td> 
</t> 
</table></td> 
<2php 
} 
证” 变量 $i 自 +1，while 循 环 结束 */ 
Si++; 
} 
> 


</tr> 
通过 上 述 代码 可 以 看 到 ， 预 览 图 片 和 显示 图 片 实际 调用 的 都 是 同一 页 面 : image.php。image.php 页 
就 是 用 来 显示 图 片 的 实际 效果 。 实 现代 码 如 下 : 
例 程 08 ”代码 位 置 ， 光盘 \TM\08\tmlog\image.php 


<?php 
include "Conn/conn.php"; // 包 含 数据 库 链接 文件 
$query="select id,tpmc,file,author,scsj from tb_tpsc where id=".$recid; // 根 据 id 生 成 查询 语句 
$result=mysql_query($query); // 执 行 查询 语句 
if(!S$result) die("error: mysql query"); // 判 断 是 否 有 返回 结果 
$num=mysql_num _rows($result); // 计 算 结 果 集 个 数 
if($num<1) die("error: no this recorder"); 
S$data = mysql_result($result,0, "file"); // 返 回 图 片 数据 
echo $data; /输出 图 片 

> 


公 注意 : mysql_result() 函 数 不 能 和 其 他 处 理 结果 集 函 数 混合 调用 。 
8.7.5 删除 图 片 的 实现 过 程 
国 。 删除 图 片 使 用 的 数据 表 : tb_tpsc 


删除 图 片 是 管理 员 才 有 的 权限 ， 在 图 片 浏览 的 实现 代码 中 ， 已 经 给 出 如 何 判断 登录 用 户 是 否 为 管 
理 员 。 当 管理 员 单 击 “ 删 除 ” 超 链接 时 ， 处 理 页 (remove.php) 会 根据 传 过 来 的 id， 删 除 对 应 的 数据 


表 中 的 数据 。 实 现代 码 如 下 : 
“401: g 


例 程 09 ”代码 位 置 : 光盘 \TM\08\tmlog\remove.php 
<?php 
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session_start(); // 开 启 session 支 持 
include "check_login.php"; // 包 含 权限 检查 文件 
include "Conn/conn.php"; // 包 含 数据 库 链接 文件 
if($_session[fig] != "1"){ // 判 断 是 否 为 管理 员 
echo "<script>alert(' 您 没有 删除 权限 ");history.go(-1);</script>"; 
} 
$sql="delete from tb_tpsc where id=".$pic_id; // 生 成 删除 语句 
Sresult=mysql_query($sql); // 执 行 删除 语句 
if($result) { // 根 据 $result 返 回 结 果 
echo "<script>alert(' 图 片 删除 成 功 !");location='browse_pic.php';</script>"; 
} 
else{ 
echo "<script>alert(' 图 片 删除 操作 失败 !");history.go(-1);</script>"; 
} 


> 


8.7.6 单元 测试 


在 进行 上 传 模块 的 测试 时 发 现 : 当 上 传 比较 大 的 图 片 时 ， 文 件 大 小 的 验证 部 分 并 没有 生效 ， 而 是 
直接 跳 过 。 在 处 理 页 中 产生 错误 ， 并 且 显 示 页 面 不 显示 图 片 。 运 行 结果 如 图 8.27 所 示 。 


Warning: fread(): supplied argument is not a valid stream resource 
in D:\AppServ\www\tmlog\tpti_ok.php on line 27 
图 片上 传 成 功 ， 请 稍 等 ... 

浏览 图 片 


四 


图 片 名 称 :sdfsdaf 上 2007-12- eS 上 传 时 间 :2007-12-20 

X 删除 X 删除 

页 次 : 1/2 页 记录 :5 条 下 一 页 尾 页 
图 8.27 上 传 图 片 错误 信息 及 显示 结果 

查看 原文 件 大 小 验证 的 代码 如 下 : 


证 判断 上 传 文件 的 大 小 ， 如 果 文 件 过 大 ， 提 示 错 误 */ 
if($_FILES[file][size] > 500000){ 
echo "<script>alert( 文 件 上 传 错误 ， 请 重新 上 传 );history.go(-1)</script>"; 


exit(); 


} 


经 反复 测试 后 发 现 : 如 果 上 传 图 片 大 于 500KB 而 小 于 2MB 时 ， 原 代码 生效 。 如 果 图 片 大 于 2MB， 
则 代码 被 跳 过 ， 这 时 输出 $_FILES[filej[size] 的 值 为 0。 原 来 ,在 配置 文件 php.ini 中 ， 
upload_mix_filesize=2MB， 也 就 是 说 ， 上 传 文件 的 大 小 超过 了 系统 设置 的 值 ， 那 么 $_FILES[file][size] 
»402. 
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返回 0， 在 判断 表达 式 中 返回 true， 代 码 自然 被 跳 过 。 
改写 验证 代码 ， 更 改 后 的 代码 如 下 : 
例 程 10 ”代码 位 置 ， 光盘 \TM\08\tmlog\tptj_ok.php 


if(($ FILES[filel[size] <= 0) or ($ FILES[filel[size] > 500000)){ 
echo "<script>alert(' 文 件 上 传 错 误 ， 或 文件 大 于 500K， 请 重新 上 传 ');history.go(-1)</script>"; 
exit(); 


} 
进行 二 次 测试 ， 问 题 没有 再 出 现 ， 系 统 正常 运行 。 


8.8 朋友 圈 模 块 设计 


8.8.1 朋友 圈 模 块 概述 


本 系统 的 朋友 圈 模 块 的 主要 功能 是 添加 、 查 询 、 删 除 好 友 ， 添 加 的 好 友 除 了 该 用 户 以 外 ， 包 括 管 
理 员 在 内 的 所 有 外 人 都 不 可 以 查看 ， 以 保证 其 个 人 隐私 不 被 外 泄 。 用 户 被 删除 时 ， 该 用 户 现 有 的 朋友 
圈 也 一 并 被 删除 。 朋 友 圈 模块 框架 图 如 图 8.28 所 示 。 


图 8.28 朋友 圈 模 块 框架 图 
8.8.2 ”朋友 圈 模 块 技术 分 析 


在 查询 好 友 的 功能 中 ， 使 用 到 了 模糊 查询 语句 ， 用 于 模糊 查找 好 友 列 表 。 模 糊 查询 语句 使 用 的 是 
like 运算 符 。 在 PHP 中 ， 带 有 like 运算 符 的 查询 语句 的 常用 格式 有 2 种 : 
(1) 使 用 通配符 “%” 的 where 子 句 
通配符 “%” 表 示 0 个 或 多 个 、 任 意 长 度 和 类 型 的 字符 ， 包 括 中 文 汉字 。 
示例 1: 表示 查找 所 有 内 容 包 含 “ 好 ” 字 的 文章 。 
select * from tb_file where content like '% 好 %'; 


示例 2: 查找 所 有 包含 “好 ” 字 或 “高 ” 字 的 文章 ， 这 时 可 以 配合 or 运算 符 来 使 用 。 代 码 如 下 : 


0. 
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select * from tb_file where content like '% 好 %' or content like '% 高 %'; 
(2) 使 用 通配符 “_” 的 where 子 句 
通配符 “_” 表 示 匹 配 任意 的 单个 字符 。 
示例 1: 查找 用 户 名 只 包含 5 个 字符 ， 其 中 后 4 个 字符 为 sof 的 用 户 。 代 码 如 下 : 
select * from tb_user where regname like ' soft; 
示例 2: 查找 所 有 以 + 开头 、 并 且 以 + 结尾 的 、 中 间 包 含 3 个 字符 的 用 户 。 代 码 如 下 : 
select * from tb_user where regname like tt; 
查找 的 结果 为 : tsoft。 


外 注意 : 使 用 MySQL 做 模糊 查询 要 注意 编码 问题 。 如果 编码 不 统一 ,那么 查询 时 就 容易 查 不 到 数据 ， 
或 返回 的 数据 不 匹配 。 所 以 在 安装 MySQL 时 ， 要 保持 和 系统 编码 的 统一 。 常 用 的 编码 格式 
有 gb2312、ISO-8859-1、utf8 和 gbk 等 。 


8.8.3 ”查询 好 友 的 实现 过 程 


国 查看 文章 、 评 论 模块 使 用 的 数据 表 : tb_friend 

当 用 户 要 查询 好 友 时 ， 单 击 “ 朋 友 圈 管理 ”/“ 查 询 朋 友信 息 ”， 显 示 查 询 页面 。 查 询 可 以 分 为 姓 
名 查询 和 编号 查询 ， 均 为 模糊 查询 。 当 用 户 输 入 要 查找 的 关键 字 后 ， 单 击 “ 检 索 ” 按 钮 ， 或 按 Enter 
键 ， 系 统 跳 到 处 理 页 进行 处 理 。 查 询 好 友 页 面 的 运行 结果 如 图 8.29 所 示 。 


| 


WICC MT 


查询 条 件 ; [至 各 卫 ] 关键 字 | 栈 | 
EEE 
编号 28 姓名 tsoft 性 别 0 生日 1980-01-14 
所 在 城市 ”上海 崇明 家 庭 住址 吉林 
邮政 编码 “13**** 家 庭 电 话 0431-12345kx* 
e-mail 。 zh####@163,com 
手机 号 码 1351XXXX359 QQ 号 。 1234retr X 删除 


图 8.29 查询 好 友 页 面 的 运行 结果 
查询 页 包含 一 个 查询 表单 ， 包 括 查 询 条 件 和 查询 关键 字 两 部 分 表单 元 素 。 主 要 表单 元 素 如 表 8.8 
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表 8.8 查询 页 表单 的 主要 元 素 属性 


method="post" action= "query_friend.php" onSubmit="return check();" 查询 好 友 表 单 
<option value="name" selected> 姓 名 </option> | 
sel 1 select 沽 El 查询 条 件 选择 
jit <option value="id"> 编 号 </option> 
text id="sel key" size="30" 查询 关键 字 


type= 


submit" name="submit" value=" 检 索 " “检索 ”按钮 
当 处 理 页 接收 到 查询 条 件 及 查询 关键 字 后 ， 生 成 模糊 查询 语句 ， 执 行 SQL 语句 并 返回 查询 结果 。 
如 果 没 有 输入 关键 字 , 则 弹出 提示 框 ; 如 果 没 有 查找 到 任何 结果 , 则 输出 “Sorry! 没 有 您 要 找 的 朋友 !”。 
处 理 页 的 关键 代码 如 下 : 
例 程 11 ”代码 位 置 ， 光盘 \TM\08\tmlog\query_friend.php 


<?php 

session_start(); // 开 启 session 支 持 
include "Conn/conn.php"; // 包 含 数据 库 链接 文件 
include "check_login.php"; // 包 含 权 限 检查 文件 
> 


<script language="javascript"> 
上 # ”JavaScript 脚 本 ， 验 证 输入 信息 ， 如 果 为 空 ， 则 弹出 提示 框 */ 
function check(form){ 
if (document.myform.sel key.value==""){ 
alert(" 请 输入 查询 条 件 !"); 


myform.sel key.focus(); 


return false; 
1 
} 
</script> 
<?php 
if($ POST[sel key]!=""){ 
$tj=$_POST[sel 4)]; // 接 收 查 询 字段 
Skey=$_POST[sel_key]; // 接 收 查 询 关 键 字 
$sql=mysql query("select * 位 om tb friend where $tj like '%S$key%' and username="'$ SESSION[username]"); 
$result=mysql_fetch_array($sql); // 执 行 查询 语句 
if($result==false){ 
echo ("[<font color=red>Sorry! 没 有 您 要 找 的 朋友 !</font>]"); 
Yelsef 
?> 
Ee <!-- 显示 记录 表单 ”二 
<?php }?> 


8.9 ”开发 技巧 与 难点 分 析 


想象 一 下 : 动态 的 下 拉 菜 单 、 半 透明 的 背景 效果 ， 鼠 标 划 过 时 的 色彩 交替 ， 给 人 一 种 亦 真 亦 幻 的 


“405。 
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视觉 冲击 和 美的 感受 ， 这 样 的 网 站 具有 更 大 的 吸引 力 。 本 系统 个 人 管理 页 面 中 的 管理 菜单 实现 的 就 是 
这 种 效果 。 当 用 户 登录 到 博客 网 站 后 ， 将 鼠标 移动 到 “朋友 圈 管 理 ” 等 导航 链接 上 时 ， 将 在 下 方 显示 
出 半 透 明 的 下 拉 式 菜单 ， 透 过 此 下 拉 菜 单 仍 可 以 看 到 页 面 上 的 内 容 ， 运 行 效果 如 图 8.30 所 示 。 


WECMN Sm FN OM 


欢迎 您 ; spcn 博客 首页 文章 管理 图 片 管理 朋友 图 管理 退出 登录 


T 添加 博客 文章 
| 查看 我 的 文章 | En | 
| 1、 今 天 中 午 要 找 讲 了 ~ 我 的 文章 | 


| 
页 次 : 171 页 记录 : 1 条 


图 830 动态 半 透明 效 果 的 下 拉 菜 单 
实现 半 透 明 背 景 的 下 拉 菜单 ， 首 先 需要 在 页 面 中 实现 下 拉 菜单 ， 然 后 再 通过 设置 下 拉 菜单 的 CSS 
样式 实现 半 透 明 效 果 。 实 现下 拉 菜 单 的 半 透 明 效 果 可 以 应 用 CSS 样式 的 透明 效果 滤 镜 alpha 实现 alpha 
属性 是 把 一 个 目标 元 素 与 背景 混合 。 这 种 “与 背景 混合 ”通俗 地 说 是 一 个 元 素 的 透明 度 ， 透 明 效果 滤 
镜 alpha 的 语法 如 下 : 


{filter:alpha(opacity=opacity,finishopacity=finishopacity ,style=style,startx=startx,starty=starty,finishx=finishx,finishy=fini 
shy)} 


滤 镜 alpha 的 各 个 参数 说 明 如 表 8.9 所 示 。 
表 8.9 alpha 滤 镜 的 各 个 参数 及 说 明 


属 性 说 阴 
代表 透明 度 水 准 。 默 认 的 范围 是 0 一 100， 其 实 是 百分比 的 形式 ， 也 就 是 0 代表 完全 透明 ，100 代 表 完全 

‘opacity 不 透明 
finishopacity | 可 选 ， 如 果 想 要 设置 渐变 的 透明 效果 ， 可 以 使 用 该 参数 指定 结束 时 的 透明 度 。 范 围 也 是 0 一 100 
Style 指定 透明 区 域 的 形状 特征 ， 其 中 0 代表 统一 形状 、1 代 表 线 形 、2 代 表 放 射 状 、3 代 表 长 方形 
Startx 代表 渐变 透明 效果 的 开始 X 坐 标 
St 代表 渐变 透明 效果 的 开始 Y 坐 标 
Finishx 代表 渐变 透明 效果 结束 X 坐 标 
Finish 代表 渐变 透明 效果 结束 Y 坐 标 


在 本 实例 中 的 menuskin 类 中 ， 设 置 了 alpha 滤 镜 的 属性 。 代 码 如 下 : 
例 程 12 ”代码 位 置 : 光盘 \TM\08\tmlog\css\style.css 


.menuskin { 
BORDER: #666666 1px solid; // 层 边框 样式 
VISIBILITY: hidden; // 层 可 见 为 隐藏 
FONT: 12px Verdana; // 层 中 的 字体 样式 和 大 小 
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POSITION: absolute; // 定 位 方式 
background-image:url("../images/item_out.gif"); // 背 景 图 片 

background-repeat : repeat-y; // 图 片 是 否 可 重复 

Filter: Alpha(Opacity=85); // 设 置 alphpa 的 opacity 属 性 等 于 85， 即 透明 度 为 85% 


} 

在 显示 页 面 中 显示 菜单 项 的 表单 引入 这 个 menuskin 类 ， 当 鼠标 划 过 特定 的 文字 时 ， 将 会 发 现 自动 
下 拉 菜 单 的 效果 为 半 透 明 的 样式 。 页 面 关键 代码 如 下 : 

例 程 13 ”代码 位 置 ， 光盘 \TM\08\tmlog\file.php 

<!-- ”弹出 层 设置 --> 


<div class=menuskin id=popmenu 
<!-- ”鼠标 进入 该 区 域 时 调用 的 js 方法 -> 
onmouseover="clearhidemenu();highlightmenu(event,'‘on")" 
<!-- ”鼠标 离开 该 区 域 时 调用 的 js 方法 -> 
‘onmouseout="highlightmenu(event,'off );dynamichide(event)" 
<!-- 设置 层 秋 顺序 和 定位 方式 -> 
style="Z-index:100;position:absolute;"> 
</div> 
<!-- 半 透 明 的 动态 下 拉 菜 单 -> 
<TABLE style="WIDTH: 580px" VERTICAL-ALIGN: text-top; cellSpacing=0 cellPadding=0 align="center"> 
<TR align="center" valign="middle"> 
<!-- 显示 登录 用 户 -> 
<TD style="WIDTH: 100px; COLOR: red;"> 欢 迎 您 :&nbsp;<?php echo 
$ SESSION[usermame]; ?>&nbsp;&nbsp;</TD> 
<!-- 显示 首页 超 链 接 -> 
<TD style="WIDTH: 80px; COLOR: red;"><SPAN style="FONT-SIZE: pt; COLOR: #cc0033"> 
</SPAN><a href="index.php"> 博 客 首 页 </a></TD> 
<!-- 显示 文章 管理 下 拉 菜 单 。--> 
<TD style="WIDTH: 80px; COLOR: red;"><a onmouseover=showmenu(event,productmenu) 
‘onmouseout=delayhidemenu() class=navlink' style="CURSOR:hand" > 文章 管理 </a></TD> 
<!-- ”显示 图 片 管理 下 拉 菜 单 -> 
<TD style="WIDTH: 80px; COLOR: red;"><a onmouseover=showmenu(event,Honourmenu) 
onmouseout=delayhidemenu() class=navlink' style="CURSOR:hand"> 图 片 管 理 </a></TD> 
<!-- ”显示 朋友 图 管 理 下 拉 菜 单 。--> 
<TD style="WIDTH: 90px; COLOR: red;"><a onmouseover=showmenu(event,myfriend) 
onmouseout=delayhidemenu() class=navlink' style="CURSOR:hand" > 朋友 圈 管 理 </a></TD> 
<?php 
店 ” 如 果 登 录用 户 为 管理 员 */ 
if($_SESSION[fig]==1){ 


二 显示 管理 员 管理 下 拉 菜 单一 一 一- > 
<TD style="WIDTH: 80px; COLOR: red;"><a onmouseover=showmenu(event,myuser) 
onmouseout=delayhidemenu() class='navlink' style="CURSOR:hand" > 管理 员 管 理 </a></TD> 


<?php 
! 
er 
<!- 一 一 -显示 退出 超 链 接 ---- > 3 
<TD style="WIDTH: 80px; COLOR: red:"><a hre 仁 "safe php"> 退 出 登录 </a></TD> 
</TR> 
</TABLE> 
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通过 代码 可 以 发 现 ， 在 每 个 超 链接 标签 <a> 里 ， 都 有 3 个 参数 ， 分 别 是 : 

onMouseOver: 鼠标 进入 该 区 域 时 的 效果 。 本 页 面 调用 了 js 方法 showmenu()。 

onMouseOut: 鼠标 移出 该 区 域 时 的 效果 。 本 页 面 调 用 js 方法 delayhidemenu()。 

style: 标签 样式 ， 本 页 面 样式 为 "CURSOR:hand:"， 显 示 一 个 手 的 形状 。 

调用 的 js 方法 就 是 实现 下 拉 菜 单 的 JavaScript 代码 : 显示 和 隐藏 菜单 。 由 于 这 段 代 码 是 通用 型 代 
码 ， 所 以 单独 放 到 一 个 js 文件 中 ， 方 便 其 他 页 调用 ，js 文件 名 为 menujs。 调 用 时 在 页 面 中 加 入 如 下 代 
码 即 可 。 


<script src="JS/menu.JS"></script> 
menu.js 文件 中 显示 、 隐 藏 菜单 和 变换 背景 等 关键 函数 的 代码 如 下 : 
例 程 14 ”代码 位 置 ， 光盘 \TM\08\tmlog\js\menujs 


上 # 浏览 器 版 本 号 检测 */ 
var I[E4=document.all&é&navigator.userAgent.indexOf("Opera")==-1 
var netscape6=document.getElementById&&!document.all 
var netscape4=document.layers 
上 # ”显示 下 拉 菜 单 函 数 */ 
function showmenu(e,vmenu,mod){ 
上 # 判断 浏览 器 版 本 */ 
if (I!document.all&&!document.getElementById&&!document.layers) 
Tetum 
上 # 菜单 内 容 */ 
which=vmenu 
上 # ”调用 clearhidemenuO) 函 数 */ 
clearhidemenu() 
让 ”调用 IE_clearshadow0 函 数 */ 
IE clearshadow() 
人 # ”根据 不 同 的 浏览 器 ， 声 明 弹 出 式 菜单 */ 
menuobj=IE4? document.all.popmenu : netscape6? document.getElementByld("popmenu") : netscape4? 
document.popmenu : "" 
menuobj .thestyle=(IE4|Inetscape6)? menuobi.style : menuobj 
if (IE4|Inetscape6) 
证 ”如 果 是 IE4 或 netscape6 浏 览 器 ， 就 调用 innerHTMIL 方 法 输出 下 拉 菜 单 */ 
menuobj.innerHTML=which 
else{ 
证 ” 否 者 使 用 write 方 法 输出 下 拉 菜 单 */ 
menuobj.document.write('<layer name="other" bgColor="#E6E6E6" width="165" 
‘onmouseover="clearhidemenu()" onmouseout="hidemenu()">'+which+'</layer>') 
上 # 关闭 数据 流 */ 


menuobj.document.close() 


} 

局 ”调用 不 同 的 方法 属性 ， 来 设置 不 同 的 浏览 器 的 宽 、 高 、 及 内 部 表格 的 大 小 、 位 置 */ 
menuobj.contentwidth=(IE4|Inetscape6)2 menuobj.offsetWidth : menuobj.document.other.document.width 
menuobj.contentheight=(IE4|lnetscape6)2 menuobj.offsetHeight : menuobj.document.other.document.height 
eventX=IE4? event.clientX : netscape6? e.clientX : e.x 

eventY=IE4? event.clientY : netscape6? e.clientY : e.y 

var rightedge=IE4? documentbody.clientWidth-eventX : window.innerWidth-eventX 

var bottomedge=IE4? document.body.clientHeight-eventY : window.innerHeight-eventY 


So 
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if (rightedge<menuobj.contentwidth) 
menuobj .thestyle.left=I[E4? document.body.scrollLeft+event X-menuobj.contentwidth+menuOffX 
netscape6? window.pageXOffset+eventX-menuobj.contentwidth : event X-menuobj.contentwidth 
else 
menuobj.thestyle.left=IE4? IE_x(event.srcElement)+menuOffX : netscape6? window.pageXOffset+teventX : 
eventX 
if (bottomedge<menuobj.contentheight&&mod!=0) 
menuobi .thestyle.top=IE4? 
document.body.scrollTopteventY-menuobj.contentheight-event.offsetY+menuOffY-23 : netscape6? 
window.pageYOffsetteventY-menuobj.contentheight-10 : eventY-menuobj.contentheight 
else 
menuobj.thestyle.top=IE42 IE_y(event.srcElement)+menuOffY : netscape6? 
window.pageYOffsetteventY+10 : eventY 
店 ”设置 标签 样式 为 可 见 */ 
menuobj.thestyle.visibility="visible" 
证 ”调用 IE_dropshadow0 方 法 */ 
IE dropshadow(menuobj,"#999999",3) 
retum false 
} 
上 # ”隐藏 下 拉 菜 单 函数 */ 
function hidemenu(){ 
if (window.menuobj) 
menuobj .thestyle.visibility=(IE4|Inetscape6)? "hidden" : "hide" 
IE clearshadow() 
’ 


function dynamichide(e){ 
if (IE4&&!menuobj.contains(e.toElement)) 
hidemenu() 
else if (netscape6&&e.currentTarget!= e.relatedTarget&&c !contains netscape6(e.currentTarget, e.relatedTarget)) 
hidemenu() 


} 
/+ 延迟 隐藏 下 拉 菜 单 函数 */ 
function delayhidemenu(O){ 
if (IE4|Inetscape6linetscape4) 
delayhide=setTimeout("hidemenu()",500) 


' 
上 停止 隐藏 菜单 函数 */ 
function clearhidemenu(){ 
if (window.delayhide) 
clearTimeout(delayhide) 
} 


上 请 设置 菜单 背景 */ 

人 # ”鼠标 移入 该 区 域 时 显示 的 背景 */ 
function overbg(tdbg){ 
tdbg.style.background='url( images/item over.gif)’ 
tdbg.style.border=" #9CA6C6 1px solid' 


’ 
证 ”鼠标 移出 该 区 域 时 显示 的 背景 */ 
function outbg(tdbg){ 
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tdbg.style.background=url( images/item_out.gif)' 
tdbg.style.border=" 


b 

让 下 拉 菜 单 内 容 */ 

/* 文章 管理 下 拉 菜 单 */ 

var productmenu='<table width=90><tr><td id=fileadd onMouseOver=overbg(fileadd) on MouseOut=outbg(fileadd)><a 
href=file.php> 添 加 博客 文章 </a></td></tr>\ 

<tr><td id=query onMouseOver=overbg(query) onMouseOut=outbg(query)><a href=query.php> 查 询 博客 文章 
</a></td></tr~\ 

<tr><td id=myfiles onMouseOver=overbg(myfiles) onMouseOut=outbg(myfiles)><a href=myfiles.php> 我 的 文章 
</a></td></tr></table>' 

上 # 图 片 管理 下 拉 菜 单 */ 

Var Honourmenu='<table width=90><tr><td id=picadd onMouseOver=overbg(picadd) onMouseOut=outbg(picadd)><a 
href-add_pic.php> 添 加 图 片 <a></td></tr\ 

<tr><td id=browse onMouseOver=overbg(browse) onMouseOut=outbg(browse)><a href=browse_pic.php> 浏 览 图 片 
</a></td></tr~\ 

<tr><td id=querypic onMouseOver=overbg(querypic) onMouseOut=outbg(querypic)><a href=query_pic.php> 查 询 图 片 
</a></td></tr></table>' 

人 # ”朋友 图 管理 下 拉 菜 单 */ 

var myfriend='<table width=90><tr><td id=friendadd on MouseOver=overbg(friendadd) 
onMouseOut=outbg(friendadd)><a href=friend.php> 添 加 到 朋友 圈 </a></td></tr>\ 

<tr><td id=browse_fri onMouseOver=overbg(browse_fri) onMouseOut=outbg(browse_fri)><a href=browse_fri.php> 浏 览 
我 的 朋友 </a></td></tr~\ 

<tr><td id=cxfriend onMouseOver=overbg(cxfriend) onMouseOut=outbg(cxfriend)><a href=query_friend.php> 查 询 朋 友 
信息 </a></td></tr></table> 

上 # 管理 员 管理 下 拉 菜 单 */ 

var myuser='<table width=90><tr><td id=queryuser onMouseOver=overbg(queryuser) 
onMouseOut=outbg(queryuser)><a href=queryuser.php> 查 询 用 户 信息 </a></td></tr>\ 

<tr><td id=browseuser onMouseOver=overbg(browseuser) onMouseOut=outbg(browseuser)><a href=browseuser.php> 浏 
览 用 户 信息 </a></td></tr>\ 

<tr><td id=managepub onMouseOver=overbg(managepub) onMouseOut=outbg(managepub)><a hre 人 =managepub.php> 
公告 管理 </a></td></tr~\ 

</table>"' 


8.10 ”登录 验证 码 技术 专题 


当今 网 络 安全 越 来 越 成 为 一 个 重要 的 问题 ， 开 发 一 个 带 验证 码 的 用 户 登 录 模 块 可 以 提高 网 站 的 安 
全 性 。 其 中 ， 验 证 码 是 随机 生成 的 ， 可 以 是 字母 、 数 字 或 汉字 ， 也 可 以 是 图 片 。 本 节 技 术 专 题 主要 就 
是 学 习 一 下 验证 码 的 儿 种 实现 方法 及 技巧 。 


8.10.1 简单 的 数字 验证 


先 来 看 一 个 简单 的 的 数字 验证 码 : 生成 一 组 4 位 的 随机 数字 ， 每 刷新 一 次 ， 显 示 的 结果 都 不 相同 。 
如 果 验 证 码 输 入 错误 ， 将 弹出 提示 窗口 。 数 字 验 证 码 运行 结果 如 图 8.31 所 示 。 


So 
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简单 的 数字 验证 码 


验证 码 : |153 1529 


AN 对 不 起 ， 您 输入 的 验证 码 不 正确 ! 


图 8.31 简单 的 数字 验证 运行 结果 


简单 的 数字 验证 码 在 开发 过 程 中 主要 应 用 两 个 函数 : 
(1) mt_rand() 函 数 
mt_rand() 函 数 主要 用 于 从 指定 参数 中 随机 去 一 个 数值 。 语 法 如 下 : 


int mt_rand([int min], [int max]); 
例如 : 从 52 一 79 之 间 取 一 个 随机 数值 。 代 码 如 下 : 
mt_rand(52,79) 


(2) intval0) 函 数 
intval0 函 数 主 要 用 于 将 变量 转 成 整数 类 型 。 语 法 如 下 : 
int intval(mixed var, int [base]); 
intval0 函 数 可 将 变量 转 成 整数 类 型 。 可 省 略 的 参数 base 是 转换 的 基数 ， 默 认 值 为 10。 转 换 的 变量 
var 可 以 为 数组 或 类 之 外 的 任何 类 型 变量 。 


8.10.2 ”数字 图 形 验证 码 
数字 图 形 验证 码 相 对 于 数字 验证 码 而 言 ， 要 稍 复杂 一 些 。 数 字 图 形 验证 码 主要 应 用 mt_rand 函数 


来 初始 化 一 组 4 位 的 随机 数 , 然后 利用 for 循环 语句 将 随机 生成 的 4 位 随机 验证 码 利用 数字 图 形 进行 输 
出 。 图 形 验 证 码 的 运行 结果 如 图 8.32 所 示 。 


数字 图 形 验 证 码 
验证 码 ， 后 柯 3574 
| 


8.32 数字 图 形 验证 码 


实现 数字 图 形 验证 码 的 关键 代码 如 下 : 
411 g 
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<!-- js 脚本 ， 判 断 文 本 框 中 输入 的 验证 码 是 否 匹 配 --> 
<script language= "javascript"> 
function check(form){ 
if(form.txt_yan.value—""){ 
alert(" 请 输入 验证 码 ");form.txt_yan.focus();retum false; 
} 


if(form.txt_yan.value!=form.txt_hyan.value){ 


alert(" 对 不 起 ， 您 输入 的 验证 码 不 正确 1");form.txt_yan.focus();return false; 


; 
} 
</script> 


-4 验证 表单 ~ 


<form name="form" method="post" action="" onSubmit="return check(form);"> 


<!-- ”验证 码 文本 框 ”--> 

<input type="text" name="txt_yan"> 

<!-- ”生成 随机 数字 图 形 验 证 码 -> 

<?php 

<!-- ”生成 随机 4 位 数 -> 
$num=intval(mt_rand(1000,9999)); 

<!-- ”使 用 for 循 环 ， 输 出 随机 4 位 数 的 图 片 格式 --> 
for($i=0;$i<4;$i++){f 


echo "<img src=images/checkcode/".substr(strval($num),$i,1).".gif>"; 


}> 
<!-- 将 随机 数 存 入 隐藏 域 -> 


<input type="hidden" name="txt_hyan" id="txt_hyan" value="<?php echo $num;?>"> 


<br> <br> 

<input type="submit" name="Submit" value=" 验 证 "> &nbsp; <input type="reset" name="Submit2" value=" 重 置 "> 
<!-- “处理 代码 段 -> 

<?php 


族 ”判断 验证 码 录 入 框 是 否 为 空 */ 
if($_POST[txt_yan]!=")!{ 
族 ” 当 输入 的 验证 码 和 隐藏 域 中 的 验证 码 相 等 时 ， 输 出 欢迎 信息 */ 
if($_POST[txt_yan] — $_POST[txt_hyan]){ 
echo "您 输入 的 验证 码 通过 ， 感 谢 您 的 加 盟 .…"; 


} 
2> 


8.10.3 ”汉字 图 形 验证 码 


汉字 图 形 验 证 码 是 目前 网 络 上 比较 流行 的 验证 码 方式 ， 这 种 验证 码 的 实现 有 一 定 的 难度 。 首 先 将 
图 片 所 对 应 的 汉字 依次 存储 到 数组 中 。 然 后 利用 Rand 函数 生成 一 个 小 于 10 的 数 ， 用 于 得 到 随机 字符 


的 位 置 ， 近 而 得 出 随机 字符 ， 并 设置 要 显示 的 随机 图 片 。 由 于 产 和 4 


E 的 随机 字符 串 是 4 位 的 ， 所 以 需要 


使 用 for 循环 语句 ， 根 据 数组 得 出 相应 图 片 的 路 径 ， 再 将 图 片 转换 成 数组 中 的 文字 ， 最 后 输出 到 浏览 


器 中 。 
以 汉字 图 形 化 显示 验证 码 的 完整 代码 如 下 : 


Re 
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<?php 
$str=array(" 大 "," 更 "," 创 "," 天 "," 科 "," 客 "," 博 "," 技 "," 立 "," 新 "); 
$word=strlen($str); 
for($i=0:81<4:$iH+){ 
$num=rand(0,$word*2-1); 
S$img=$img."<img src=' images/checkcode/".Snum.".gif width="16' height="16>"; /显示 随机 图 片 


$pic=$pic.$str[$num]; // 将 图 片 转换 成 数组 中 的 文字 
} 


8.11 本 章 总 结 


本 章 的 博客 管理 系统 首先 介绍 了 博客 的 基本 概念 、 发 展 前 景 、 影 响 范围 及 博客 网 的 功能 分 类 ， 使 
读者 对 当今 主流 博客 有 了 一 个 大 致 的 认识 。 其 次 ， 实 现 了 一 个 博客 系统 、 包 含 所 有 基本 功能 的 项 目 开 
发 ， 使 读者 对 如 何 开发 一 个 博客 网 站 有 了 一 个 初步 的 了 解 。 最 后 ， 希 望 读 者 通过 自己 的 努力 ， 来 逐步 
完善 和 加 强 这 个 博客 网 的 实用 功能 ， 最 终 达 到 一 个 令 自己 满意 的 作品 。 


第 章 


企业 快 信 系 统 


( Apache+PHP+Access+VWVeb Service 实现 ) 


随 着 互联 网 的 迅猛 发 展 ， 人 与 人 之 间 的 沟通 方式 也 在 发 生 着 翻天 禾 地 的 变化 
不 再 是 单纯 的 面对面 的 交流 、 书 信之 间 的 往来 或 者 电话 沟通 ， 而 是 选择 通过 网 络 进 
行 即时 沟通 。 短 信和 E-mail 已 经 成 为 时 下 人 与 人 之 间 沟 通 的 另 一 座 桥梁 。 为 此 ， 越 
来 越 多 的 网 站 都 开始 提供 发 送 E-mail 和 手机 短信 的 功能 。 上 短信 和 E-mail 以 其 方便 
快捷 、 零 距离 、 低 成 本 等 优势 受到 众多 企业 的 青 睦 ,成 为 企业 移动 商务 的 首先 方式 。 
本 章 的 企业 快 信 系统 就 是 讲解 如 何在 企业 中 实现 短信 和 E-mail 群发 的 功能 。 通 过 学 
习 本 章 ， 读 者 可 以 : 


了 解 企 业 快 信 系统 的 开发 流程 

掌握 Access 数据 库 的 创建 方法 

掌握 PHP 如 何 通 过 ADO 方式 来 连接 Access 数据 库 
掌握 使 用 Web Service 发 送 短信 的 方法 

熟悉 POP3 服务 路 的 安装 与 配置 

熟悉 SMTP 服务 路 的 安装 与 配置 

掌握 使 用 imap 电子 邮件 系统 国 数 发 送 和 接收 邮件 的 方法 


于 于 于 于 吾 吾 至 
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9.1 开发 青 景 


随 着 企业 信息 化 的 飞速 发 展 ， 市 场 瞬息 万 变 ， 作 为 企业 必须 能 够 随时 掌握 市 场 的 变化 ， 针 对 其 变 
化 作出 判断 ， 并 且 能 够 第 一 时 间 将 决策 进行 传达 。 因 此 ， 和 急需 一 套 既 能 从 多 方 获取 到 信息 ， 又 能 将 信 
息 进 行 准确 传达 的 企业 信息 管理 系统 。 企 业 快 信 系 统 就 是 信息 化 发 展 下 时 代 的 产物 ， 不 但 可 以 从 外 部 
获取 到 大 量 的 数据 信息 ， 而 且 可 以 将 内 部 的 信息 传达 出 去 。 


9.2 ”系统 分 析 


9.2.1 需求 分 析 


企业 为 适应 市 场 的 发 展 ， 实 现 更 加 入 性 化 的 管理 ， 加 强 企业 内 部 之 间 、 企 业 与 外 部 之 间 的 沟通 ， 
为 此 需要 开发 一 套 完整 的 企业 快 信 管理 系统 。 根 据 企 业 的 实际 需求 ， 企 业 快 信 系统 需要 提供 短信 群发 、 
邮件 收发 等 功能 。 通 过 对 企业 日 常 业务 的 考察 、 分 析 ， 并 结合 短信 及 邮件 自身 的 特点 ， 得 出 本 系统 要 
求 具有 以 下 功能 : 
实现 对 客户 和 同事 信息 的 管理 。 
实现 对 常用 短语 及 其 类 别 进行 管理 。 
实现 短信 群发 的 功能 。 
实现 邮件 的 发 送 和 接收 功能 。 


办 办 办 


9.2.2 ”可行 性 分 析 


开发 任何 一 个 项 目 ， 首 要 做 的 就 是 进行 需求 分 析 ， 然 后 根据 需求 分 析 的 结论 再 进行 项 目的 可 行 性 
分 析 ， 降 低 项 目 开 发 风险 ， 避 免 人 力 、 物 力 和 财力 的 浪费 ， 最 终 圆满 完成 项 目的 开发 。 项 目 开 发 的 可 
行 性 分 析 主 要 从 两 个 方面 进行 : 一 方面 是 经 济 可 行 性 ， 另 一 方面 是 技术 可 行 性 。 

1. 经 济 可 行 性 

采用 短信 和 邮件 作为 企业 的 移动 通信 手段 ， 将 给 企业 对 内 、 对 外 进行 信息 传递 与 沟通 带 来 革命 性 
的 变化 ， 从 而 使 得 移动 办 公 、 客 户 服务 、 员 工 沟通 等 运作 效率 显著 提升 ， 而 成 本 则 显著 下 降 。 合 理 地 
发 挥 短信 和 邮件 的 作用 ， 实 现 资源 的 充分 利用 ， 从 而 降低 企业 的 成 本 。 

2. 技术 可 行 性 

企业 快 信 系 统 的 开发 主要 应 用 到 Web Service、POP3 服务 器 、SMTP 服务 器 和 imap 电子 邮件 系统 
函数 。 首 先 完成 配置 POP3 服务 器 和 SMTP 服务 器 的 安装 和 配置 工作 ， 然 后 合理 地 运用 Web Service 和 
imap 电子 邮件 系统 函数 就 可 以 顺利 完成 该 项 目的 开发 。 

*“415 。 乡 
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9.3 系统 设计 


9.3.1 系统 目标 


根据 前 面 所 作 的 需求 分 析 和 对 企业 进行 的 实际 考察 ， 现 制定 出 企业 快 信 系统 应 达到 的 目标 。 
界面 设计 美观 大 方 。 

操作 灵活 、 方 便 。 

提供 完整 的 客户 和 同事 信息 ， 方 便 进行 短信 和 邮件 的 发 送 。 

提供 短信 和 邮件 的 群发 功能 。 

为 短信 发 送 提供 常用 短语 。 

对 输入 的 数据 进行 严格 的 数据 检验 ， 避 免 出 现 数据 录入 的 错误 。 

系统 运行 稳定 、 数 据 库 安全 可 靠 。 


办 


因 办 办 办 办 轨 


9.3.2 系统 功能 结构 


根据 企业 快 信 系统 的 特点 ， 可 以 将 其 分 为 系统 信息 管理 、 邮 件 管理 、 发 送 短 信 、 修 改 密码 、 帮 助 
和 退出 系统 6 个 部 分 ， 各 个 部 分 及 其 包括 的 功能 如 图 9.1 所 示 。 


EE 发 们 条 
客户 信息 管理 | 和 
同事 信息 管理 上 | 天 -| 
常用 短语 管理 站 [发送 记录 
短信 记录 管理 


图 9.1 系统 功能 结构 图 


9.3.3 ”系统 流程 图 


企业 快 信 系统 的 系统 流程 如 图 9.2 所 示 。 


Re 
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编写 邮件 内 容 


客户 同事 信息 


图 9.2 系统 流程 图 
9.3.4 系统 预览 
企业 快 信 由 系统 多 个 程序 页 面 组 成 ， 下 面 仅 列 出 几 个 典型 页 面 ， 其 他 页 面 参 见 光盘 中 的 源 程序 。 


系统 登录 页 面 如 图 9.3 所 示 ， 该 页 面 用 于 实现 管理 员 登 录 。 主 页 面 如 图 9.4 所 示 ， 该 页 面 用 于 显示 
系统 导航 、 操 作业 务 流程 和 版 权 信 息 等 功能 。 


ETT 


ms [加 


nF 


用 户 名 : Fo 
灾 码 : |®@0 


提交 | [ 重 置 | 


图 9.3 系统 登录 页 面 (光盘 \TMV09\qykxvindex.php) 图 9.4 主页 面 (光盘 \TM\09\qykx\indexs.php) 


“417。 
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发 送 短信 页 面 如 图 9.5 所 示 ， 该 页 面 用 于 实现 将 短信 息 同时 发 给 多 个 接收 者 的 功能 ， 同 时 ， 为 方便 
用 户 还 提供 了 从 客户 及 同事 列表 中 选择 接收 者 及 从 常用 短语 中 选择 指定 信息 的 功能 。 发 送 邮件 页 面 如 
图 9.6 所 示 ， 该 页 面 用 于 实现 将 邮件 同时 发 给 多 个 接收 者 的 功能 ， 同 时 ， 为 方便 用 户 还 提供 了 从 客户 及 
同事 列表 中 选择 接收 者 的 功能 。 


3 业 嘱 入 V1.0 


图 沾 由 :克昌 省 信用 企业 负 信 曾 现 系统 


Wa [| 
3 
re 国际 


于 
i 


ED [as 


in 
EJ 
再 人 用人 生理 失 


Ee pa esis Pp i 


FE 1 


图 9.5 发 送 短信 (光盘 \TM\09\qykx\ short_note.php) 图 9.6 发 送 邮 件 (光盘 \TM\09\qykx\ sendmail.php) 


接收 邮件 的 页 面 如 图 9.7 所 示 , 该 页 面 用 于 实现 邮件 信息 的 接收 , 并 且 可 以 实现 删除 和 查看 指定 邮 
件 的 操作 。 查 看 邮件 内 容 的 页 面 如 图 9.8 所 示 ， 该 页 面 用 于 实现 对 指定 邮件 信息 的 输出 , 包括 邮件 的 主 
题 、 内 容 、 附 件 和 发 送 人 等 信息 。 


= ~ 日 
wh 全 vi. 广 Rv. 


人 


pe 
Be 
E29 
a 
Ee 
时 


图 9.7 接收 邮件 的 页 面 (光盘 \TM\09\qykx\ lookmail.php) 图 9.8 发送 邮件 页 面 (光盘 \TM\09\qykx\sendmail.php) 


9.3.5 开发 环境 


在 开发 企业 快 信 系统 时 ， 该 项 目 使 用 的 软件 开发 环境 如 下 : 
1. 服务 器 端 


操作 系统 : Windows 2003 Server/Linux (推荐 ) 。 
服务 器 : Apache 2.0。 
SMTP 服务 器 。 


Re 
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POP3 服务 器 。 

PHP 软件 : PHP 5.0。 

数据 库 : Access 2003。 

开发 工具 : Dreamweaver 8。 
浏览 器 : IE 6.0 及 以 上 版 本 。 

分 辨 率 : 最 佳 效 果 1024X 768 像素 。 
客户 端 

浏览 器 : IE 6.0 及 以 上 版 本 。 

分 辨 率 : 最 佳 效果 1024X 768 像素 。 


固 加 图 加 回回 


M3 


办 轨 


9.3.6 文件 夹 组 织 结构 


在 进行 网 站 开发 之 前 ， 要 对 网 站 的 整体 文件 夹 组 织 架构 进行 规划 。 对 网 站 中 使 用 的 文件 进行 合理 
的 分 类 ， 分 别 放置 于 不 同 的 文件 夹 下 。 通 过 对 文件 夹 组 织 架构 的 规划 ， 可 以 确保 网 站 文件 目录 明确 、 
条 理 清晰 ， 同 样 也 便于 网 站 后 期 的 更 新 和 维护 。 企 业 快 信 的 文件 夹 组 织 架构 如 图 9.9 所 示 。 


日 国 vi 文件 根 目录 文件 来 
加 “om 连接 数据 库 交 件 存 储 位 置 
图 ss Css 样 式 文件 存储 位 置 
[| data Access 数 据 库 文件 存 鱼 位 置 
加 inages 一 一 一 一 一 一 一 一 一 一 一 一 一 图 片 交 件 存 储 的 位 置 
田 - 国 nails 一 一 一 一 一 一 一 一 一 一 一 一 邮件 收发 系统 立 件 夹 
BB mr 发 送 短信 应 用 的 类 文件 
田 - 国 socket 一 一 一 一 一 一 一 一 一 一 一 一 通过 socket 编 程 发 送 短 信 文 件 夹 


图 9.9 企业 快 信 文 件 夹 组 织 结构 


9.4 SMTP 和 POP3 服务 器 的 安装 与 配置 


想 要 实现 邮件 的 收发 功能 必须 要 对 SMTP 服务 器 和 POP3 服务 器 进行 安装 和 配置 ， 下 面 就 来 讲解 
一 下 这 两 个 服务 器 的 安装 和 配置 过 程 。 
9.4.1 SMTP 服务 器 的 安装 和 配置 


SMTP 是 简单 邮件 传输 协议 ， 提 供 客户 端 向 服务 器 端 发 送 邮件 的 功能 ， 即 客户 端 向 服务 器 发 出 请 
求 指令 ， 服 务 器 端 则 给 出 应 答 。 本 实例 将 以 Windows 2003 Server 为 例 介绍 SMTP 服务 器 的 安装 方法 。 
(1) 打开 “控制 面板 ”， 选择“ 添加 或 删除 程序 ”选项 ， 打 开 如 图 9.10 所 示 的 “添加 或 删除 程序 ” 


窗口 。 
9. 
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名 添加 或 副 除 程序 EE =I9lx| 

当前 安装 的 程序 排序 方式 @): [名 称 司 

间 ppServ 2.5.7 Cemove only) 大 小 51STNB 

已 使 用 有 时 

上 一 次 使 用 日 期 2006-12-3 

要 更 改 此 程序 或 将 它 从 计算 机 删除 ， 单 击 “ 更 改 /删除 ”。 更 改 /删除 

@ Macronedia Dreanweaver MX 大 小 109. 00MB 

图 Macronedia Extension Nanager 大 小 SSMB 

HY Nicrosoft Office 2000 Premiun 大 小 204.00MB 

刘 远程 管理 工具 大 小 4.63NB 


钥 件 &) 


图 9.10 “添加 或 删除 程序 ”窗口 


(2) 单 击 图 9.10 所 示 窗 口中 的 “添加 /删除 Windows 组 件 ” 按钮 , 打开 如 图 9.11 所 示 的 “Windows 
组 件 向 导 ” 窗 口 。 该 窗口 中 列 出 系统 的 所 有 组 件 ， 如 果 “ 应 用 程序 服务 器 ”选项 组 前 面 的 复 选 框 已 经 
处 于 选中 状态 ， 说 明 该 组 件 已 经 被 安装 ， 否 则 需要 选中 安装 。 

(3) 选择 “应 用 程序 服务 器 ”选项 后 ， 单 击 “ 详 细 人 信息” 按钮 将 打开 如 图 9.12 所 示 的 “应 用 程序 
服务 器 ”窗口 。 


Windows 钥 件 向 导 x|| 
Yindows 扯 件 天 
可 以 添加 或 出 除 Windows 的 组 件 。 
应 用 程序 服务 器 | 
2 1 Se ee 
扯 件 吕 ): 应 用 程序 服务 器 的 子 姐 件 忆 ): 


站 到 天 的 同 辣 文件 和 打印 服务 TD TS | 
口 于 索引 服务 0.0 四 加 佑 昌 用 网 洛 ch 访问 0.0 妥 
园 2 网络 服务 2.4 Wp 口 图 启用 网 络 nrc 访问 0.0 妥 
] 三 消息 队列 6.5 妥 
门 电 远 种 安 间 服务 19 岂 到 口 穷 应 用 程序 服务 器 控制 oom 司 


描述 : le 信息 服务 CTS) 和 应 用 程序 服务 器 控制 擅 玉 : Pe Rak a 
Exte Server Puge (ASF) 站 


ension 和 Active 


可 用 瑞生 斌 间 - ER 
ers oie 详细 信息 四 ) 
ee 一 12rl4.3 加 二 
9.11 Windows 组 件 向 导 图 9.12 应 用 程序 服务 器 


(4) 选中 “Internet 信息 服务 (IIS) ” 复 选 杠 ， 单 击 “ 确 定 ”按钮 后 开始 安装 。 

(5) 安装 完毕 后 , 还 需要 对 SMTP 服务 器 进行 设置 , 选择 控制 面板 中 的 “Internet 信息 服务 (IIS) ” 
选项 将 打开 如 图 9.13 所 示 的 “Internet 信息 服务 〈IIS) 管理 ”窗口 ， 需 要 在 该 窗口 中 创建 新 域 ， 因 为 
SMTP 只 能 向 SMTP 服务 器 中 已 经 存在 的 域名 范围 发 送 邮件 。 

(6) 右 击 图 9.13 中 的 “ 域 ” 选 项 ， 在 弹出 的 快捷 菜单 中 选择 “新 建 ”/“ 域 ”命令 ， 如 图 9.14 
所 示 。 


Se. 
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到 | 
| 写 文件 操作 (& 查看 W 窗口 (w) 帮助 由 |=lel2 


中 了 | 全 | 国 | 问 局 | 岛 


司 访 息 凶 务 域名 EE 
SP gzrst 民 者 有 可 ES ET 
用 Intemet 信息 服务 (II5) 管 理 器 6 可 4 | 入 163.con 本 地 [ 自 定 多 ) 
= 1 申 量 入 hcom 本 地 ( 自 定义) 
各 文件 [) 染 作 和 查 看 信 窑 wD) 大 |=181 由 区 入 snacon 本 地 ( 目 定义) 
和 了 | 四 轿 | 国 图 | 区 sg Syren 可 地 ( 自 十 X) 
Trent 人 二 大 务 Ex S| 
日 拐 NRzT5( 本 地 计算 机 ) ET sc Ew 
量 司 FTP 站 点 相 池 (和 定义 ) 
加 -号 应 用 程序 池 本 激 自 定 风 
号 声 Fs 本 地 ( 自 定 以 ) 
加 -号 web 服务 扩展 
日 各 执 以 SMTP 庶 开 服 务 器 Ny 
生 当前 会话 
ET 
图 9.13 SMTP 虚拟 服务 器 图 9.14 新 建 域 


(7) 打开 如 图 9.15 所 示 的 “新 建 SMTP 域 向 导 ” 窗 口 ， 选 中 “别名 ” 单 选 按 钮 ， 单 击 “ 下 一 步 ” 
按钮 ， 打 开 如 图 9.16 所 示 的 窗口 ， 在 该 窗口 中 输入 要 发 送 邮件 的 域名 ， 单 击 “ 完 成 ”按钮 ， 即 可 实现 


SMTP 服务 器 的 配置 。 
TOTTT 所 | 新 建 SMTP 域 向 导 
欢迎 使用 新 建 SNTP 域 向 导 | 十 名 
人 玉林 UEt amr UR 务 器 上 外 陵 一 此 城 接收 的 邮件 的 地 址 空间 (30 ni erosoft, con) 
指定 城关 型 
斑 远程 @) 名 称 吕 ) 
[of BEY) zh com 
wm mi 


图 9.15 新 建 SMTP 域 向 导 


图 9.16 添加 域名 


9.4.2 POP3 服务 器 的 安装 和 配置 


POP (全称 为 Post Office Protocol, 邮局 协议 ) 用 于 电子 邮件 的 接收 , 现在 常用 第 三 版 , 因此 称 POP3。 
通过 POP 协议 ， 客 户 机 登录 到 服务 器 后 ， 可 以 对 自己 的 邮件 进行 删除 ， 或 是 下 载 到 本 地 。POP3 的 常 


用 命令 如 表 9.1 所 示 。 


命令 | 参数 


表 9.1 POP3 常用 命令 
描述 


USER Usemame 


此 命令 与 下 面 的 pass 命 令 若 都 发 送 成 功 ， 将 使 状态 转换 


PASS Password 
APOP Name , Digest 


向 POP3 服 务 器 发 送 指定 邮箱 的 登录 密码 ， 进 行 密码 验证 
Digest 是 MD5 消 息 摘要 


STAT None 


请 求 服务 器 发 回 关 于 邮箱 统计 资料 邮件 总 数 和 总 字 节 数 ) 


UIDL 回 送 邮件 唯一 标识 符 
LIST 回 送 邮 件数 量 和 每 个 邮件 的 大 小 


og 
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续 表 
命 令 描述 
RETR sgh] 处 理 | 回 送 由 参数 标识 的 邮件 的 全 部 文本 
DELE | [Mse# 处 理 ”| 服务 器 将 由 参数 标识 的 邮件 标记 为 删除 ， 由 QUIT 命 令 执行 
RSET None 处 理 服务 器 将 重 置 所 有 标记 为 删除 的 邮件 ， 用 于 撤销 DELE 命 令 
TOP sp 处 理 ”| 服务 器 将 回 送 由 参数 标识 的 邮件 前 行内 容 ，n 是 正 整 数 
NOOP 服务 器 返回 一 个 肯定 的 响应 ， 不 做 任何 操作 
QUIT | None 更 新 | 断 开 与 POP3 的 连接 ， 同 时 将 带 有 删除 标记 的 邮件 进行 物理 删除 


了 解 POP3 协议 及 其 常用 命令 后 ， 下 面 就 来 介绍 POP3 服务 器 的 安装 与 配置 。 
(1) 选择 “Windows 组 件 向 导 ” 窗 口中 的 “电子 邮件 服务 ”选项 ， 单 击 “ 下 一 步 ” 按 钮 即 可 完成 
POP3 服务 器 的 安装 ， 如 图 9.17 所 示 。 


全 注意 : 打开 “Windows 组 件 向 导 ” 窗 口 的 方法 请 详 见 实例 “SMTP 服务 器 的 安装 与 配置 ”。 


到 
vindows 租 件 一 
可 以 添加 或 胡 隔 Windors 的 姐 件 。 | ey 


Se es 


Es| 


20 
证 节 om 到 
坟 术 。 人 8, 民 甸 提 供 了 电子 冲服 务 。 风 时 全 安装 入 提名 伯 人 多 


所 需 磋 盘 裤 间 : 0.4 上 
可 jt 3 EE 


《上 - 步 四 | 下 - 步 ol mW | wh | 


图 9.17 “Windows 组 件 向 导 ” 窗 口 


(2) 完成 POP3 服务 器 的 安装 后 还 需要 对 服务 器 进行 设置 。 打 开 POP3 服务 器 后 ， 右 击 本 机 服务 
器 名 (如 MRZTS) ， 在 弹出 的 快捷 菜单 中 选择 “新 建 ”/“ 域 ”命令 ， 打 开 “ 添 加 域 ” 对 话 框 ， 如 
图 9.18 所 示 。 在 “添加 域 ” 对 话 框 中 添加 一 个 新 域名 后 单 击 “ 确 定 ” 按 钮 ， 新 域 将 被 创建 成 功 。 

El 
| 为 文件 但 ” 折 作 (A) ”查看 V) 窗 D(w) 帮助 HD) esl 
沾 二 | 向 | 铬 国民 |@ | 
区 PR 
a 和 邮箱 工大 小 | 消息 

EE | 

域名 ) 

ps3. eonl 

Ce ] ws | 
| FT | 上 | 


图 9.18 “添加 域 ”对 话 框 
\ * 422. 
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(3) 新 域 创建 完成 后 , 需要 在 新 域 中 创建 邮箱 , 选择 新 创建 的 域名 后 单 
建 ”/“ 邮 箱 ” 命 令 后 ， 将 弹出 如 图 9.19 所 示 的 “添加 邮箱 ”对 话 框 ， 在 此 输 
现 邮 箱 的 创建 工作 ， 并 可 以 在 图 9.20 所 示 的 窗口 中 查看 创建 结果 。 


鼠标 右键 , 依次 选择 “新 
入 邮箱 名 称 和 密码 后 即 实 


=/9)x| 
吉文 二 加 ”操作 (查看 W。 从 DG。 下 外 | = 车 


二 白 | 日 马 | ET 局 


下 闻 箱 [ 


图 9.19 添加 邮箱 


加 


JU 成 功 添加 了 邮箱 。 


贡 2 在 输入 登录 信息 时 邮件 客户 必须 使 


使 用 明文 身份 验证 : 
1zh@263. com 

件 服务 器 :MRZTS 
使 用 安全 密码 身份 验证 ; 
;1zh. 263. com 

件 服务 器 :NRZTS 


厂 不 再 显示 此 消息 


图 9.20 查看 邮箱 创建 结果 


9.5 数据库 设计 


Microsoft Access 是 一 种 关系 型 数据 库 管理 系统 。 适 用 于 中 小 企业 管理 ， 
库 ， 而 且 可 以 应 用 于 网 络 环境 。 


9.5.1 数据 库 概念 设计 


不 仅 可 以 应 用 于 本 地 数据 


根据 以 上 各 节 对 系统 所 进行 的 需求 分 析 、 系 统 设 计 ， 规 划 出 本 系统 中 使 用 的 数据 库 实 体 对 象 分 别 为 


“423。 
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客户 信息 实体 、 同 事 信 息 实体 、 管 理 员 信息 实体 、 短 信 信 息 实体 、 邮 件 信 息 实体 和 常用 短语 信息 实体 。 
1. 客户 信息 实体 
客户 信息 实体 包括 姓名 、 地 址 、 电 话 、 生 日 、 邮 箱 和 类 别 。 客 户 信息 实体 E-R 图 如 图 9.21 所 示 。 


图 9.21 客户 信息 实体 E-R 图 
2. 同事 信息 实体 
同事 信息 实体 包括 姓名 、 地 址 、 电 话 、 生 日 、 邮 箱 和 类 别 。 同 事 信 息 实体 E-R 图 如 图 9.22 所 示 。 


图 9.22 同事 信息 实体 E-R 图 


3. 管理 员 信息 实体 
管理 员 信 息 实体 包括 管理 员 名 和 管理 员 密 码 两 个 属性 。 管 理 员 信 息 实体 E-R 图 如 图 9.23 所 示 。 


图 9.23 管理 员 信息 实体 E-R 图 


4. 短信 信息 实体 
短信 信息 实体 包括 IP 地址、 发 信 手 机 号 码 、 收 信和 手机 号 码 、 短 信 内 容 、 发 信 时 间 和 短信 标题 等 属 
性 。 短 信 信 息 实体 E-R 图 如 图 9.24 所 示 。 


So 
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发 信 手 机 
号 码 
发 信 时 间 


图 9.24 短信 信息 实体 E-R 图 


5. 邮件 信息 实体 
邮件 信息 实体 包括 IP 地 址 、 发 件 邮 箱 、 收 件 邮箱 、 邮 件 标 题 和 发 件 时 间 等 属性 。 邮 件 信息 实体 E-R 
图 如 图 9.25 所 示 。 


发 件 时 间 
Car ) 发 件 邮箱 


邮件 信息 


收 件 邮 箱 邮件 标题 


图 9.25 邮件 信息 实体 E-R 图 


6. 常用 短语 信息 实体 
常用 短语 信息 实体 包括 短语 内 容 和 短语 类 别 两 个 属性 。 常 用 短语 信息 实体 E-R 图 如 图 9.26 所 示 。 


短语 类 别 


图 9.26 短信 信息 实体 E-R 图 
9.5.2 创建 数据 库 及 表 


在 本 项 目 使 用 Access 2003 数据 库 ， 数 据 库 名 称 为 db_mail_shortnote。 下 面 详细 介绍 数据 库 的 创建 
过 程 。 


1. 创建 数据 库 
在 创建 数据 库 时 ， 首 先 启动 Access 2003， 然 后 创建 名 为 db_mail_shortnote 的 数据 库 。 创 建 数据 库 
的 具体 步骤 如 下 : 


(1) 选择 “开始 ”/“ 所 有 程序 ”/Microsoft Office/Microsoft Office Access 2003 命令 ， 打 开 Access 
2003 数据 库 的 运行 环境 ， 在 此 环境 中 单 击 “ 新 建 ” 按 钮 进行 数据 库 的 创建 ， 如 图 9.27 所 示 。 
*“425 。 乡 
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[So ER WAR RT 
[sa| 
Microsoft Office 


* 连接 到 Wicres 


有 icroseft 
0ffice Online 


9.27 打开 Microsoft Access 


(2) 首先 在 右 侧 将 弹出 “新 建文 件 ” 列 表 项 ， 在 此 选择 “ 空 数 据 库 ”命令 ， 然 后 手动 选择 新 建 数 
据 库 的 存储 位 置 ， 如 图 9.28 所 示 。 


EEC 
文件 四 编辑 外 视图 WW 插入) 工具 CD) 窗口 多 帮助 中 
A AAR A PAE MAR A 


搜索 
篇 0ffice online 模板 
| 


tj 4 


图 9.28 创建 数据 库 


(3) 数据 库 的 存储 位 置 选择 完成 后 ， 首 先 需要 在 “文件 名 ”文本 框 中 输入 新 建 数据 库 的 名 称 ， 如 
db_mail_shortnote， 该 名 称 为 本 实例 的 数据 库 名 称 ， 然 后 通过 单 击 “ 创 建 ” 按 钮 完成 数据 库 的 创建 ， 如 
图 9.29 所 示 。 

2. 创建 数据 表 
根据 在 数据 库 概念 设计 中 给 出 的 数据 库 实体 E-R 图 ， 可 以 设计 数据 表 结 构 。 使 用 Access 数据 库 创 
建 数据 表 的 具体 步骤 如 下 : 

(1) 双击 打开 新 创建 的 db_mail_shortnote 数据 库 。 

(2) 在 该 数据 库 中 ， 双 击 “使 用 设计 器 创建 表 ” 选 项 后 ， 进 行 新 数据 表 的 创建 。 此 时 将 打开 创建 
新 数据 表 的 对 话 框 ， 如 图 9.30 所 示 ， 在 此 输入 所 需要 创建 的 字段 名 称 ， 并 通过 “数据 类 型 ”下 拉 列 表 
来 选择 字段 所 属 的 类 型 。 


Se 
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:文件 四 ”编辑 外 视图 WW 插入 I) 工具 上 窗口 帮助 0 
D 芝 上 晶 及 | 岛 及 仇 | 半 生生 | 习 -| 到 -| 双 -| 筷 o| 村 | 
蕊 eil shortnote : 数 乞 库 因 
硬 3 乓 四 刀 训 + 四 基建 四 | X | aa 二 国庆 
对 得 轩 EEHEREEEE 


D 
菇 中叶 六 要 晓 轨 


入 NN 车 全 加 地 


ls 


图 9.29 成 功 创建 数据 库 


=I9lx| 
字段 名 称 数据 类 型 因 
到 ia 目 动 编导 I 
I pe 文本 
|userpwd 文本 
于 | 加 
字段 展 性 
常规 | 查阅 | 
字段 大 小 长 整 型 
新 值 进 增 
格式 
到 | 让 
索引 有 侈 重复 ) 人 


图 9.30 创建 新 数据 表 
(3) 输入 完 所 需 创建 的 字段 后 ， 选 择 “ 文 件 ”/“ 保 存 ” 命 令 ， 在 弹出 的 “另存 为 ”对 话 框 中 输 
入 所 需要 的 数据 表 名 称 即 可 ， 如 tb_user， 如 图 9.31 所 示 。 
了 引 x| 


表 名 称 也) : 


图 9.31 保存 新 数据 表 
“427。 g 
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(4) 单 击 “ 确 定 ”按钮 完成 数据 表 的 创建 。 


9.5.3 ”数据库 逻辑 结构 设计 


企业 快 信 中 应 用 的 db_mail_shortnote 数据 库 主 要 包含 6 个 数据 表 ， 为 了 使 读者 对 本 系统 数据 库 中 
的 数据 表 有 一 个 更 清晰 的 认识 ， 笔 者 设计 一 个 数据 表 树 型 结构 图 ， 如 图 9.32 所 示 。 
可] db_mail_shortnote 
回 使 用 设计 器 创建 表 
回 | 使 用 向 导 创 建 表 
回 ” 通过 输入 数据 创建 表 
国 tb_customer 客户 信息 表 
国 tb_colleagua 一 一 同事 依 息 表 
加 tb_mail 邮件 信息 表 
国 tb_short 一 一 短 信 信 息 表 
国 tb_mte 一 一 一 一 一 一 一 一 一 一 一 一 常用 短语 信息 表 
国 tb_user 管理 员 信 息 表 


图 932 数据 表 树 型 结构 图 

各 数据 表 的 逻辑 结构 如 图 9.2 一 图 9.7 所 示 。 

1. tb_user (管理 员 信 息 表 ) 

管理 员 信息 表 主 要 用 于 保存 管理 员 的 基本 信息 ，tb_user 表 的 结构 如 表 9.2 所 示 。 
表 9.2 tb_user 表 的 结构 


username 


userpwd. 
2. tb_colleague (同事 信息 表 ) 
同事 信息 表 主 要 用 于 保存 企业 中 员工 的 个 人 信息 ，tb_colleague 表 的 结构 如 表 9.3 所 示 。 
表 9.3 tb_colleague 表 的 结构 


字段 名 称 


colleague id 
colleague name 姓名 
colleague address 地 址 


colleague tel 


colleague mail 


colleague_birthday 


colleague_catego 


.428 。 
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3. tb_customer (客户 信息 表 ) 
客户 信息 表 主 要 用 于 保存 与 企业 长 期 合作 关系 的 客户 的 信息 , tb_customer 表 的 结构 如 表 9.4 所 示 。 


表 9.4 tb_customer 表 的 结构 


字段 名 称 


customer id 


Customer name 


customer address 
customer_tel 电话 
customer mail 邮箱 


customer_birthda 


customer_categor 


4. tb_mail (邮件 信息 表 ) 
邮件 信息 表 主 要 用 于 保存 邮件 的 发 送 记 录 ，tb_mail 表 的 结构 如 表 9.5 所 示 。 
表 9.5 tb_mail 表 的 结构 


字段 名 称 字段 描述 
mail id | 和 编 | | | | 办 标 识 
mail ip 5 
mail formuser 
mail touser | 广 + | i0 | | 吾 | 疏 # 人 
mail title 00 有 
mail date TT |] | hn 
5. tb_short (短信 信息 表 ) 
短信 信息 表 主 要 用 于 存储 短信 的 发 送 记录 ，tb_short 表 的 结构 如 表 9.6 所 示 。 

表 9.6 tb_short 表 的 结构 


中 
涉 |= 
鹤 | 茎 
> 尾 


吕 


be 
ji 
fF 
El 
[本 


short id 唯一 标识 
short_ip IP 地 址 
short_tel 发 送 手机 号 码 


short_tels, 接收 手机 号 码 
short_content 短信 和 内容 
short_date 发 送 时 间 


标题 


short title 


加 ”tb_note( 常 用 短语 信息 表 ) 
常用 短语 信息 表 主 要 用 于 存储 常用 短语 的 内 容 ，tb_note 表 的 结构 如 表 9.7 所 示 。 
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表 9.7 tb_note 表 的 结构 


note id 


note_content 


note_catego 


9.6 首页 设计 


9.6.1 首页 概述 


管理 员 要 通过 用 户 名 和 密码 登录 到 企业 快 信 系统 的 主页 面 。 系 统 主页 面 主要 包括 系统 导航 栏 、 功 
能 展示 区 和 信息 选择 区 3 部 分 。 其 中 ， 导 航 栏 主要 包括 连接 短信 、 连 接 邮件 、 修 改 密码 、 帮 助 和 退出 
系统 ， 功 能 展示 区 主要 用 于 实现 发 送 短信 和 邮件 收发 ， 以 及 对 系统 信息 管理 的 操作 ;在 信息 选择 区 中 
以 树 状 菜单 的 形式 展示 出 系统 中 的 客户 信息 、 同 事 信息 和 系统 信息 管理 的 内 容 。 

下 面 看 一 下 本 案例 中 提供 的 首页 该 首页 在 本 书 光盘 中 的 路 径 为 \TM\09\qykx\index.php， 如 图 9.33 
所 示 。 


ee: Olverual win vio 
> 会 业 快 信 V1. 0 1 人 


系统 导航 栏 


企业 快 信 欢 迎 您 ， 当前 登录 用 户 : Tseft 连接 短信 “| 连接 地 件 _| 修改 密码 | 帮助 | 退出 系统 


欢迎 : 欢迎 您 使 用 企业 快 信 管理 系统 。 加 不 统 信息 管理 
人 @ 专 户 信息 管理 
添加 手机 号 : 添加 人 @ 同事 信息 管理 
发 送 的 手机 号 码 人 @O 祝 用 短语 省 理 
全 反 信 记录 管理 
Oz#r 

人 @ 同事 

注册 手机 号 人 池 用 短语 


注册 密码 
信息 选择 区 


严 发 信号 码 收 信号 码 短信 内 容 发 送 时 间 操作 
192. 168. 1.59 13604338784 13604336784 sdfsd sd 2007-12-6 6:01:18 ”删除 
192. 168. 1.59 13604338784 13604338764 dfedfedfe 2007-12-6 6:04;41 ”删除 
发 送信 息 2 条 每 页 显示 5 条 第 1 页 / 共 ! 页 1 


Ez 
图 9.33 ”企业 快 信 首 页 
\ 。430 。 


短信 内 容 


9.6 


第 9 章 企业 快 信 系统 (Apache+PHP+Access+Web Service 实现 ) 


.2 首页 技术 分 析 


在 图 9.33 所 示 的 首页 中 ， 系 统 导航 栏 和 版 权 信息 栏 是 固定 不 变 的 ， 只 是 功能 展示 区 和 信息 选择 区 


根据 系统 提供 的 变量 不 同 而 进行 不 同 功能 模块 之 间 的 跳 转 ， 其 主要 应 用 switch 证 语句 来 完成 。 当 单 击 导 
航 栏 中 的 按钮 时 ， 系 统 就 会 提交 一 个 变量 值 给 switch 语句 ， 然 后 switch 语句 会 根据 提供 的 变量 进行 判 


断 ， 


最 终 输 出 指定 的 模块 。 
点 用 switch 语句 实现 不 同 功能 模块 之 间 的 跳 转 ， 关 键 代码 如 下 : 


例 程 01 ”代码 位 置 ， 光盘 \TM\09\qykx\indexs.php 


<?php 
switch($lmbs){ // 执 行 switch 语 句 ， 根 据 提交 的 变量 值 
case "连接 短信 " : // 判 断 提交 的 变量 是 否 与 连接 短信 匹配 
include "short_note.php"; /如 果 相 匹配 ， 则 执行 include 包 含 语句 ， 调 用 short_note.php 文 件 
break; /跳出 循环 
case "连接 邮件 ": 
include "mail.php"; 
break; 
/这 里 省 略 了 部 分 代码 
Case // 当 变量 值 为 空 时 
include "short_note.php"; /调用 该 文件 
break; 
} 
> 


9.6.3 首页 的 实现 过 程 


国 首页 使 用 的 数据 表 : tb_customer、tb_colleague、tb_mail 、tb_note、tb_short 
主页 面 的 实现 过 程 可 以 归结 为 3 个 部 分 ， 首 先 判断 登录 用 户 是 否 为 管理 员 ， 如 果 不 是 管理 员 则 不 


能 进入 到 该 系统 ， 然 后 设置 主页 面 的 导航 栏 ， 最 后 通过 switch 语句 实现 不 同 功能 模块 之 间 的 跳 转 。 


员 ， 


判断 登录 用 户 权 限 的 原理 是 获取 登录 用 户 的 用 户 名 ， 如 果 用 户 名 变量 存在 ， 则 说 明 该 用 户 是 管理 
否则 该 用 户 就 不 是 正确 的 登录 ， 将 弹出 提示 信息 “您 没有 正确 登录 ”， 返 回 到 系统 的 登录 页 面 。 


关键 代码 如 下 : 

例 程 02 ”代码 位 置 ， 光 盘 \TM\09\qykx\indexs.php 

<?php 
session_start(); // 初 始 化 session 变 量 
include_once("conn/conn.php"); // 连 接 数 据 库 
if($username=—=true){ 1/ 判断 用 户 登录 的 变量 是 否 为 真 

> 

<!-> 这 里 省 略 了 执行 内 容 <!-> 

<?php 
}else{ // 如 果 变 量 不 为 真 则 执行 下 面 的 代码 


echo "<script>alert(' 您 没有 正确 登录 !");window.location.href~'index.php';</script>"; 


01. 
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1 


> 


主页 面 的 导航 栏 是 通过 设置 超 链接 来 完成 的 ， 并 且 为 超 链接 设置 变量 标识 符 ， 指 定 不 同 的 变量 值 ， 
用 于 实现 不 同 功能 模块 之 间 的 跳 转 。 关 键 代 码 如 下 : 


例 程 03 ”代码 位 置 ， 光盘 \TM\09\qykx\indexs.php 


<!--> 指 定 连 接 到 indexs.php 文 件 ， 使 用 变量 标识 符 为 Imbs<!--> 
<td width="78" align="center"> 

<ahref-"indexs.php?lmbs= 连 接 短信 " class="STYLE1"> 连 接 短信 </a> 
</td> 
<td width="75" align="center"> 

<a hre 人 "indexs.php?lmbs= 连 接 邮 件 " class="STYLE1"> 连 接 邮 件 </a></td> 
<!--> 这 里 使 用 的 是 onClick 事 件 ， 调 用 一 个 弹出 窗口 ， 并 且 指定 窗口 的 大 小 <!--> 
<td width="77" align="center"> 

<a href="#" class="STYLE1" 

‘onClick="MM_openBrWindow('update_pwd.php',",'toolbar=yes,width=440,height=219")"> 修 改 密码 </a> 

</td> 


最 后 通过 switch 语句 实现 不 同 模块 之 间 的 跳 转 ， 其 关键 代码 已 经 在 主页 面 技术 分 析 中 给 出 ， 这 里 
不 再 殉 述 。 


9.7 ”系统 信息 管理 模块 设计 


9.7.1 系统 信息 管理 模块 概述 


加 客户 信息 、 站 
除 同 事 信息 、 同事 信息 的 显示 和 提交 同事 信息 ; 常用 短语 管理 包括 瀛 加 常用 和 8 信息 、 删除 党 用 短语 、 
常用 短语 的 显示 和 提交 常用 短语 。 系 统 信 息 管理 模块 的 功能 结构 如 图 9.34 所 示 。 


系统 信息 管理 
oT 息 到 息 


由 


| ] 司 | 
添 | | 提 信 本 提 | | 删 | | 显 | 添 | | 山 | | 显 | | 提 
加 | | 变 | | 除 | | 息 | | 加 | | 变 | | 除 | | 示 | | 加 | | 除 | | 示 | | 变 
客 | | 信 | | 客 | | 显 | 同 | | 信 | | 同 | | 售 | | 短 | | 短 | | 各 | | 运 
户 | | 息 | | 户 | | 示 || 事 | | 息 | | 事 | | 息 | | 语 | | 语 | | 语 | | 语 


图 9.34 系统 信息 管理 模块 的 功能 结构 


So 
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9.7.2 ”系统 信息 管理 模块 技术 分 析 


在 系统 信息 管理 模块 中 有 这 样 一 个 功能 ， 将 系统 中 客户 、 同 事 的 电话 或 者 邮箱 地 址 直接 提交 到 指 
定 的 位 置 ， 便 于 手机 号 码 和 邮箱 地 址 的 选择 。 该 功能 的 实现 主要 应 用 session 变量 ， 其 原理 与 购物 车 是 
相同 的 。 首 先 从 数据 库 中 读 取 到 指定 的 电话 号 码 ， 然 后 将 选择 的 电话 号 码 添加 到 一 个 session 变量 中 
进行 存储 ， 最 后 在 短信 发 送 功能 模块 中 读 取 session 变量 中 存储 的 电话 号 码 。 

这 里 以 短信 发 送 模块 中 的 客户 电话 号 码 的 选择 为 例 进行 讲解 ， 首 先 从 数据 库 中 读 取 客 户 信息 ， 输 
出 客户 姓名 , 并 且 设 置 超 链接 指定 变量 标识 ides 的 值 为 客户 信息 的 ID, 将 变量 值 提交 到 che4.php 页 中 。 
关键 代码 如 下 : 

例 程 04 ”代码 位 置 ， 光盘 \TM\09\qykx\select.php 


<2php 
$sql="select * from tb_customer"; // 读 取 数 据 库 中 数据 
S$rs=new com("adodb.recordset"); // 应 用 类 
S$rs->open($sql,$conn,1,1); // 执 行 查询 语句 
while(!$rs->eof){ /循环 输出 读 取 到 的 数据 

$fields=$rs->fields(customer id); /变量 赋值 
27> 
<tr> 


<!--> 设 置 超 链接 ， 将 常用 短语 的 ID 值 提交 到 che.php 页 中 <!--> 
<td><a href="che4.php?idss=<?php $fields=$rs->fields(customer id):echo Sfields->value:?>"> 
<?php $fields=$rs->fields(customer name);echo $fields->value;?></a></td> 
<!-->---- 一 -------- 一 -一 一 一 -- 一 : <!--> 
</tr> 
<?php ”Srs->movenext; } ”// 语 句 执行 结束 ?> 


然后 在 che4.php 页 中 根据 获取 的 idss 变量 值 ， 将 客户 信息 的 ID 值 存储 到 创建 的 session 变量 
producelistss 中 ， 在 将 客户 的 ID 传递 到 短信 发 送 页 之 前 。 首 先 要 判断 ID 在 session 变量 中 是 否 已 经 存 
在 ， 如 果 存 在 则 提示 “该 电话 号 码 已 经 被 选中 !”; 如果 不 存在 则 将 值 存储 到 session 变量 producelistss 
中 保存 ， 并 且 跳 转 到 短信 发 送 页 面 中 。 程 序 关 键 代码 如 下 : 

例 程 05 ”代码 位 置 ， 光盘 \TM\09\qykx\che4.php 


<2php session start(); /初始 化 session 变 量 
if($_SESSION[username]=—""){ // 判 断 是 否 是 正确 登录 
echo "<script>alert(' 请 先 登录 后 才 可 以 发 送 短信 !");history.back();</script>"; 
exit;} 
[9 Sidss=strval($_GET[idss]); // 获 取 超 链接 提交 的 变量 值 
@ $arrayss=explode("(@",$_SESSION[producelistss]); /以 @ 来 分 割 session 变 量 中 的 值 
for($i=0;$i<count($arrayss)-1;$i++){ /| 循环 读 取 数 组 中 的 值 
if($arrayss[$i]—S$idss){ // 判 断 session 变 量 中 是 否 存在 超 链接 提交 的 变量 值 
echo "<script>alert(' 该 电话 号 码 已 经 被 选中 !"):history.back0;</script>"; 
exit;} 3 
目 $_SESSION[producelistss]=$_SESSION[producelistss].Sidss."(@"; // 将 $idss 添 加 到 session 变 量 中 
$ SESSION[quatityss]=$ SESSION[quatityss]."1@"; 
@ header("location:indexs.php?lmbs= 连 接 短 信 "); 1// 跳 转 到 发 送 短 信和 页 面 
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< 代码 贴 二 
@ $_GET[idss]: 获取 超 链接 中 变量 提交 的 值 . 
@ explode(): 将 字符 囊 依 指定 的 字符 囊 或 字符 separator 切 开 。 


array explode(string separator, string string, [int limit]) 


该 函数 返回 由 字符 串 组 成 的 数组 ， 每 个 元 素 都 是 string 的 一 个 子 事 ,它们 被 字符 囊 separator 作为 边界 点 分 隔 出 来 。 
如 果 设 置 了 limit 参数 ， 则 返回 的 数组 包含 最 多 limit 个 元 素 ， 而 最 后 那个 元 素 将 包含 string 的 剩余 部 分 ; 如 果 separator 
为 空 字符 事 (") ，explode0) 函 数 将 返回 false; 如 果 separator 所 包含 的 值 在 string 中 找 不 到 ， 那 么 explode() 函 数 将 返回 
包含 string 单个 元 素 的 数组 ; 如 果 参 数 limit 是 负数 ， 则 返回 除了 最 后 的 -limit 个 元 素 外 的 所 有 元 素 。 

目 $_ SESSION[producelistss]: 定义 的 session 变量 ， 将 $idss 的 值 添加 到 session 变量 中 。 

@ header(): 实现 页 面 之 间 的 跳 转 ， 这 里 跳 转 到 发 送 短信 页 面 。 


最 后 在 发 送 短信 页 面 中 从 session 变量 中 获取 到 提交 的 电话 号 码 ， 其 中 主要 应 用 的 就 是 explode() 
函数 和 implode() 函 数 。 从 session 变量 中 获取 到 值 后 ， 以 该 值 为 条 件 执 行 查询 语句 ， 从 tb_customer 表 
中 读 取 到 对 应 的 电话 号 码 ， 最 后 以 隐藏 域 的 形式 将 电话 号 码 进行 提交 。 程 序 的 关键 代码 如 下 : 

例 程 06 ”代码 位 置 ， 光盘 \TM\09\qykx\short_note.php 


<?php 
$arrayss=explode("@",$_ SESSION[producelistss]); /以 @ 分 隔 session 变 量 producelistss 中 存储 的 数据 
$arrayquatityss=explode("(@",$_SESSION[quatityss]); 。 // 以 @ 分 隔 session 变 量 quatityss 中 存储 的 数据 
while(list($name,$value)=each($_POST)){ // 通 过 while 语 句 和 list 函 数 循环 读 取出 数组 中 的 数据 
for($i=0:$i<count($arrayss)-1:$i++)f 
if(($arrayss[$i])==S$name){ 
Sarrayquatityss[$i]=$value; // 输 出 变量 值 
1 


} 
$_SESSION[quatityss]=implode("(@",$arrayquatityss); 。 // 将 数组 $arrayquatityss 中 的 数据 以 @ 进 行 输 出 
for($i=0;$i<count($arrayss)- 1;$i++){ 
$idss=$arrayss[$i]; // 输 出 数组 中 的 数据 
if($idss!=""){ /判断 如 果 $idss 的 值 不 为 空 
/如 果 idss 的 值 不 为 室 ， 则 执行 下 面 的 查询 语句 ， 条 件 为 customer id 的 值 等 于 Sidss 的 值 
$sql='select * from tb _ customer where customer id='.$idss."; 
S$rsss=new com("adodb.recordset"); 


S$rsss->open($sql,$conn,3,1); // 执 行 查询 语句 


?> 

<!--> 使 用 隐藏 域 提交 客户 电话 号 码 <!--> 

<input type="hidden" name="colleague tel[]" value="<?php $fields=$rsss->fields(customer tel);echo 
S$fields->value;?>"><?php $fields=$rsss->fields(customer tel):echo $fields->value:;?> 

去 -~>-- 一 一 一 一 一 一 一 -一 -一 - < --> 


<?php }  ) 2> 
个 注意 : 该 技术 不 只 在 获取 客户 的 电话 号 码 中 使 用 ,在 获取 同事 电话 号 码 和 常用 短语 时 都 应 用 到 该 技 
术 ， 并 且 在 邮件 发 送 模块 中 也 应 用 到 该 技术 来 获取 对 应 客户 或 者 同事 的 邮箱 地 址 。 
S 。434 。 
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9.7.3 客户 信息 管理 模块 的 实现 过 程 


国 客户 信息 管理 使 用 的 数据 表 : tb_customer 
在 系统 信息 管理 模块 的 设计 中 ， 各 个 子 功能 模块 的 实现 方法 是 相同 的 。 下 面 以 客户 信息 管理 为 例 ， 
讲解 一 下 如 何 实现 客户 信息 的 添加 、 删 除 和 显示 。 客 户 信息 管理 模块 的 运行 结果 如 图 9.35 所 示 。 


二 
一 alvewual xinve 
> 


NALE 业 快 信 V1.0 


企业 快 信 欢 迎 您 ， 当前 登录 用 户 : Tseft 连接 短信 “| 连接 邮件 | 修改 密码 | 帮助 | 退出 系统 


人 二 信息 管理 
© 同事 信息 匠 理 
人 @ 第 用 短语 管理 
@ 志 辣 记录 管理 
Or 
OF 

人 % 用 知 滞 


潘 r+ 13604338784 pppasina com 11-03 长 春 市 网 pz 
合计 1 人 每 页 显示 10 条 信息 第 ! 页 / 共 ! 页 


图 9.35 客户 信息 管理 模块 的 运行 结果 


客户 信息 管理 模块 主要 包括 信息 添加 、 删 除 、 显 示 和 提交 4 部 分 内 容 ， 其 中 有 关 提 交 使 用 的 技术 
已 经 在 技术 分 析 中 做 了 详细 的 讲解 ， 这 里 不 再 袭 述 。 这 里 主要 讲解 信息 添加 、 删 除 和 显示 的 方法 。 

客户 信息 的 添加 和 删除 操作 是 在 客户 信息 显示 的 页 面 中 完成 的 ， 客 户 信息 显示 主要 通过 
customer_gl.php 文件 来 完成 ， 在 该 页 中 对 数据 库 中 存储 的 数据 进行 输出 ， 并 且 以 分 页 的 形式 进行 显示 。 

首先 连接 数据 库 , 然 后 从 数据 库 中 读 取 客 户 信息 , 最 后 应 用 while 循环 语句 以 分 页 的 形式 进行 显示 。 
程序 的 关键 代码 如 下 : 

例 程 07 ”代码 位 置 ， 光盘 \TM\09\qykx\customer_gl.php 


<?php 
include("conn/conn.php"); // 连 接 数据 库 
$sql="select * from tb_customer"; // 创 建 查 询 语句 
Sres=new com("adodb.recordset"); /应 用 类 
@ Sres->open($sql,Sconn,3,1); // 执 行 查询 语句 
Sres->pagesize=10; // 定 义 变量 每 页 显示 10 条 记录 


“45. 
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/根据 $_GET 获 取 的 值 显 示 页 面 信息 


© if((trim(intval($_GET[page]))—"")ll(intval($_GET[page])>$res->pagecount)ll(intval($_GET[page])<=0){ 
Spage=l1; // 执 行 第 一 页 
}else{ 
Spage=intval($_GET[page]): /获取 变量 提交 的 值 
} 
if($res->eof || Sres->bof) { // 为 空 时 输出 没有 信息 
> 
<tr><td height="20" colspan="6" bgcolor="#F 8F8F8"><div align="center" class="STYLE1"> 没 有 信息 </div></td></tr> 
<?php 
}else{ 
S$res->absolutepage=$page; // 定 义 变量 
Smypagesize=$res->pagesize; // 将 记录 的 值 赋 给 给 变量 
while(!$res->eof && $mypagesize>0){ /执行 while 循 环 语句 
?> 
<tr> 


i // 省 略 了 部 分 HTML 代 码 

<td align="center" bgcolor="#F8F8F8"><a href="delete_colleague_customer.php?Imbs=<?php echo 
$_GET[Imbs];?>&customer=<?php $fields=$res->fields(customer id):echo $fields->value;?>" class="STYLE1"> 删 除 
</a></td> 


<?php 
$mypagesize--; 
S$res->movenext; 
} 
} 
> 
Ah 代码 由 二 


@ $res->open($sql,$conn,3,1);: 执行 SQL 语句 ， 其 中 “3” 代 表 可 读 写 方式 ， 当 前 记录 集 指 针 可 自由 移动 并 可 看 到 
新 增 记录 ; “1” 代 表 默 认 锁定 类 型 ， 记 录 集 只 读 ， 不 能 修改 记录 。 
四 intval() 函 数 : 获取 变量 的 整数 值 。 


上 述 代码 中 实现 读 取 数 据 库 中 数据 ， 并 且 为 分 页 技术 的 实现 定义 变量 ， 有 关 分 页 的 详细 代码 可 以 
参考 本 书 的 光盘 。 

客户 信息 添加 功能 在 customer_gl.php 页 中 通过 超 链接 打开 的 窗口 中 完成 ， 其 中 主要 应 用 的 是 
onClick 事件 ， 调 用 一 个 MM_openBrWindow 函数 ， 其 中 设置 连接 文件 为 insert_customerphp， 指 定 窗 
口 的 宽度 是 440， 高 度 为 219。 关 键 代码 如 下 : 


例 程 08 ”代码 位 置 : 光盘 \TM\09\qykx\customer_gl.php 


<script type="text/JavaScript"> 
function MM openBrWindow(theURL,winName,features) { ~ //v2.0 
window.open(theURL,winName,features); // 设 置 弹出 窗口 

bh 

</script> 

<!-- 应 用 onclick 事 件 调用 函数 ， 实 现 弹 出 窗口 --> 

<td align="center" bgcolor="#E9F7FD"><a href="#" class="STYLE1" 
‘onClick="MM_openBrWindow('insert_customer.php',",'toolbar=yes,width=440,height=219")"> 添 加 客户 </a></td> 


Se 
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客户 信息 的 删除 功能 是 根据 在 customer_gl.php 页 中 获取 的 客户 信息 数据 ID, 设置 超 链接 将 客户 信 
息 数 据 ID 作为 变量 值 提交 到 delete_colleague_customer.php 页 中 执行 删除 的 操作 ， 在 delete_colleague_ 
customer.php 页 中 ， 将 客户 信息 ID 作为 执行 删除 语句 的 条 件 。 程 序 的 关键 代码 如 下 : 


例 程 09 ”代码 位 置 ， 光盘 \TM\09\qykx\delete_colleague_customer.php 


<?php include("conn/conn.php"); // 连 接 数据 库 
if($colleague==true){ /判断 提交 的 变量 值 是 否 为 空 
$sql='delete from tb_colleague where colleague_id=-'$colleague."; /创建 删除 语句 
S$rs=new com("adodb.recordset"); // 应 用 类 
S$rs->open($sql,Sconn,3,1); /| 执行 删除 语句 


echo "<script>alert(' 同 事 信 息 删 除 成 功 !");window.location.href='indexs.php?lmbs=$_GET[Imbs]&lmlb= 同 事 信 息 
管理 ';</script>"; 
} 
> 


9.7.4 单元 测试 


在 对 系统 信息 管理 模块 进行 测试 的 过 程 中 ， 当 打开 同事 信息 管理 模块 时 ， 输 出 如 图 9.36 所 示 的 
页 面 。 


姓名 电话 邮箱 生日 地 址 添加 同事 
潘 y+ 13604338784 ”pkhBsina com 11-3 长 春 市 册 除 
潘 *# 13604338784 。 pkhBsina com 可， 长 春 市 删除 
潘 ** 13604338784 ”pkhasina. com 11-3 长 春 市 册 除 
潘 ** 13604338784 ”pkhBsina. com 11-3 长 春 市 删除 
潘 ** 13604338784 ”pkhasina. com 11-3 长 春 市 删除 
潘 #* 13604338784 pkhlsina. com 11=3 长 春 市 册 除 
潘 #* 13604338784 pkhlsina. com 11=3 长 春 市 册 除 
潘 y+ 13604338784 pkhlsina. com 11-3 长 春 市 删除 
潘 #* 13604338784 ”pkhasina com 3 长 春 市 贡 除 
潘 *+ 13604338784 ”pkhBsina com 到 < 长 春 市 删除 
合计 2 人 每 页 显示 10 条 信息 第 1 页 / 共 1 页 1 


图 936 同事 信息 管理 数据 输出 结果 


从 这 个 输出 结果 中 可 以 看 到 ， 在 输出 查询 结果 的 过 程 中 将 同一 条 记录 循环 输出 10 次 。 从 而 可 以 判 
断 出 程序 中 存在 一 个 逻辑 错误 ， 即 在 执行 查询 语句 的 过 程 没有 将 指针 的 位 置 指向 下 一 条 记录 ， 而 是 将 
指针 当前 位 置 的 数据 输出 10 次 。 查 看 程序 中 的 代码 ， 出 现 错误 的 地 方 如 图 9.37 所 示 。 

PHP 是 通过 预先 定义 类 com 来 使 用 ADO 方法 操纵 Access 数据 库 的 , 在 通过 $rs->open 执行 查询 语 
句 的 过 程 中 ， 一 次 查询 结束 之 后 必须 应 用 $rs->movenext 语句 将 指针 的 位 置 指向 下 一 条 记录 ， 和 否则 查询 
语句 不 会 自动 执行 下 一 查询 ， 也 就 是 导致 循环 输出 10 条 相同 记录 的 原因 。 其 正确 的 代码 输出 应 该 是 在 
执行 while 循环 语句 后 应 用 $rs->movenext 语句 将 指针 的 位 置 指向 下 一 条 记录 。 正 确 代码 输出 如 图 9.38 


所 示 。 
4 
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《2?php 《2?php 
belse{ }else{ 
bros >abeolutenseer pege: a 
mypagesize=$rs->pagesize:; hiletl GF 2 0 
whilel!l$rs->eof && $mypagesize>0){ 2> Whilel!$rs Yeo Snypagesize>0) { 
tg <- 一 -一 -一 生 环 答 出 查询 出 的 语句 一 一 -一 -- 
|- 循环 输出 查询 出 的 语句 一 -一 一 一 cophp 人 
《“?php _ jnmypagesize- 一 ; 
$nypagesize——; $rs->movenext ; 终止 本 次 循环 
} 
} 1 
?> ?> 
图 937 程序 中 出 现 的 逻辑 错误 图 9.38 正确 的 代码 输出 


9.8 ”发 送 短信 模块 设计 
9.8.1 发送 短信 模块 概述 


发 送 短信 功能 的 实现 主要 应 用 的 是 WebService， 这 里 使 用 的 是 新 浪 网 提供 的 一 种 发 送 短信 的 Web 
Service, 有 关 Web Service 技术 将 在 技术 分 析 中 进行 详细 讲解 。 在 该 模块 中 不 但 可 以 进行 单条 短信 发 送 ， 
而 且 可 以 进行 短信 群发 。 其 操作 的 流程 如 图 9.39 所 示 。 


添加 手机 号 码 


选择 手机 号 码 


添加 短信 内 容 


添加 常用 短语 


输入 注册 手机 号 码 


存储 发 送 记录 


图 9.39 短信 发 送 的 操作 流程 
9.8.2 发送 短信 模块 技术 分 析 
在 发 送 短信 模块 中 主要 应 用 的 是 由 新 浪 提 供 的 Web Service， 新 浪 提供 的 Service 的 地 址 是 


http://smsinter.sina.com.cn/ws/smswebservice0101.wsdl。 在 这 个 Service 中 提供 一 个 发 送 短 消息 的 方法 
sendXml()。sendXml 方法 中 的 6 个 参数 均 为 string 类 型 ， 并 且 sendXml 方法 的 返回 值 也 是 string 类 型 。 


Sa 


第 9 章 企业 快 信 系统 (Apache+PHP+Access+Web Service 实现 ) 
该 方法 的 语法 格式 如 下 : 
string SendXml (carrier , userid , password , mobilenumber , content , msgtype ) 
参数 说 明 如 表 9.8 所 示 。 
表 9.8 sendXml 方 法 的 参数 说 明 


参 数 说 了 明 
运营 商 名 称 ， 具 体 使 用 时 此 参数 并 没有 什么 具体 要 求 ， 所 以 这 里 面 可 以 任意 输 写 ， 输 入 的 字符 串 也 
不 会 在 对 方 手机 中 有 任何 显示 
在 新 浪 网 上 注册 的 手机 号 ， 注 册 手 机 所 用 的 地 址 是 http://sms.sina.com.cn 
用 户 在 新 浪 网 成 功 注册 手机 后 所 反馈 的 密码 


mobilenumber | 要 发 送 短信 到 对 方 的 手机 号 码 
content 所 要 发 送 短 消息 的 内 容 
发 送 短 消息 的 类 型 ， 由 于 本 实例 发 送 的 不 是 彩信 ， 所 以 输入 Text 表 示 短 信 内 容 为 文本 


只 需要 将 上 述 参数 中 涉及 到 的 内 容 以 表单 的 形式 提交 到 该 方法 中 ， 就 可 以 完成 短信 的 发 送 。 
9.8.3 短信 发 送 模块 的 实现 过 程 
国 ”短信 发 送 模块 使 用 的 数据 表 : tb_colleague、tb_short、tb_note 


当 管 理 员 进 入 到 企业 快 信 管 理 系统 以 后 ， 默 认 展示 的 就 是 短信 发 送 的 功能 页 面 ， 其 运行 结果 如 
图 9.40 所 示 。 


过 去 、 Give re yn iS 
在 业 快 信 V1.0 


企业 快 信和 欢迎 您 t 当前 登录 用 户 : Tseft 连接 短信 “| 连接 邮件 | 修改 密码 | 帮助 | 


四 欢迎 : 欢迎 您 使 用 企业 快 信 管理 系统 。 


添加 手机 号 : 。 [13578665813 添加 -之 
改过 的 手机 号 码 人 
13804338784 13578685813 括 除 Os 
© 3 用 知 汪 
加 新 年 快乐 


注册 手机 号 1360433#*#* 


注册 密码 eeee 


图 9.40 短信 发 送 功能 的 运行 结果 
在 发 送 短信 模块 中 主要 应 用 两 个 文件 : 一 个 是 short_note.php 文件 ， 用 于 创建 一 个 提交 短信 内 容 的 
“439 。 
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表单 ， 包 括 发 送 的 手机 号 码 、 短 信 内 容 、 注 册 手 机 号 码 和 注册 密码 等 内 容 ， 另 一 个 是 对 表单 中 提交 的 
数据 进行 处 理 send.php 文件 , 在 该 文件 中 将 数据 提交 到 sendXml0 方 法 中 完成 短信 的 发 送 , 并 且 将 短信 


发 送 的 记录 存储 到 数据 库 中 。 
在 short_note.php 文件 中 创建 一 个 forml 表单 ， 用 于 提交 发 送 短信 的 相关 信息 。Forml 表单 中 的 重 
要 属性 如 表 9.9 所 示 。 
表 9.9 ”发 送 短信 中 使 用 的 重要 表单 元 素 
名 称 重要 属性 含义 
二 To ‘post" action="send.php" onSubmit="javascript: retum 表单 
checkitsO” 
ia name=" " value="<?php Sfields=S$rs->fields(colleague_tel);echo 同事 电话 
Sfields->value:?>" 
本 value="<?php $fields=$rsss->fields(customer tel);echo 客户 电话 
Sfields->value:?> 
colleague tel value="<?php echo $ids;?>"><?php echo $ids;?> 添加 的 电话 
regtel class="inputcss" id="regtel" size="30" 注册 手机 号 码 
regpwd class="inputcss" id="regpwd" size="30" 注册 密码 
Submit class="buttoncss" id="Submit" value=" 发 送 " 提交 表单 
在 short_note.php 文件 中 还 可 以 实现 客户 、 同 事 电 话 以 及 常用 短语 的 自动 添加 功能 ， 有 关 该 功能 的 
实现 已 经 在 系统 信息 管理 模块 设计 一 节 中 的 技术 分 析 中 进行 了 详细 的 讲解 ， 这 里 就 不 再 獒 述 。 


当 完 成 表单 内 容 的 填写 后 ， 就 可 以 将 表单 中 的 内 容 提交 到 send.php 文件 中 ， 在 该 文件 中 完成 短信 
的 发 送 ， 首 先 将 短信 的 发 送 记录 存储 到 数据 库 中 ， 然 后 将 数据 以 数组 的 形式 提交 到 sendXml() 方 法 中 完 


成 短信 的 发 送 。 关 键 代码 如 下 : 
例 程 10 ”代码 位 置 ， 光盘 \TM\09\qykx\send.php 


<?php include_once("conn/conn.php"); 
if($_POST[colleague_tel]==""){ 


// 连 接 数 据 库 
// 浏 断 电话 号 码 是 否 为 空 


echo "<script>alert(' 请 填写 发 送 的 手机 号 码 !");history.back();</script>"; 


jelsef 
$carrier=" 吉 林 省 明日 科技 有 限 公司 "; 
$userid=trim($_ POST[regtel]); 
$password=trim($_ POST[regpwd]); 
$content=trim($_ POST[mess]); 
$data=date("Y-m-d H:i:s"); 
Sip=getenv(‘REMOTE_ADDR"); 


// 获 取 标 题 

// 获 取 发 送 手机 号 码 
/获取 密码 

/获取 短信 内 容 
/获取 时 间 
/获取 站 地 址 


while(list($name,$value)=each($_POST[colleague_tel])){// 读 取 要 发 送 的 电话 号 码 


iflis_numeric($value)==true){ 
$mobilenumber=$value; 
$msgtype="Text"; 
店 向 数据 库 中 添加 发 送 短 信 的 记录 */ 


$sql="insert into 


// 判 断 电话 格式 是 否 正 确 
// 将 获取 的 电话 号 码 附 给 变量 
// 指 定 短信 为 文本 格式 


tb short(short ip,short tel,short tels,short content,short date,short title)values('$ip','$userid','$mobilenumber','$content','$ data', 


'$carrier)"; 


So 
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Srs=new com("adodb.recordset"); 


S$rs->open($sql,$conn,3,3): /| 执行 添加 语句 
/*. ee = | 
0 include('nusoap/lib/nusoap.php"); // 读 取 PHP 类 文件 ， 实 现 短信 的 发 送 
让 将 数据 以 数组 的 形式 添加 到 sendXml 方 法 中 */ 
@ $s=new soapclient('http://smsinter.sina.com.cn/ws/smswebservice0101.wsdl','WSDL'); 
© $s->call('sendXml',array('parameters' =>array('carrier’ => $carrier,'userid'=> $userid,'password' 一 
$password,mobilenumber => $mobilenumber'content => $content,'msgtype' => $msgtype))); 
J #/ 
echo "<script>alert('" 短 信 发 送 成 功 !");window.location.hre 位 "indexs.php?Imbs= 连 接 短信 ';</script>"; 
并 
> 
< 代码 贴 十 


@include: 通过 include 语句 包含 nusoap.php 类 文件 。 
@ soapclient: 应 用 soapclient 创建 对 象 。 
上 @ $s->call: 应 用 call() 方 法 传递 参数 。 


上 述 代码 中 包含 一 个 外 部 文件 nusoap.php， 该 文件 中 包含 一 组 开源 的 ,用 来 通过 HTTP 收发 SOAP 
消息 的 PHP 类 。 

通过 调用 WebService 的 方式 实现 短信 的 发 送 ， 首 先 应 该 从 http://dietrich.ganx4.con/nusoap/ 处 下 载 
nusoap.php 文件 ， 并 在 程序 中 用 include0 函 数 将 nusoap.php 文件 包含 进来 ， 然 后 用 soapclient 类 创建 一 
个 soapclient 对 象 ， 该 类 的 初始 化 参数 设置 为 Web Service 的 URL 地址 ， 并 通过 该 类 的 call0) 方 法 调用 
Web Service 中 的 远程 方法 ，call0 方 法 中 的 参数 sendXml 是 Web Service 提供 的 远程 方法 名 ， 

“array(parameters' =>array('carrier => $carrier,'userid'=> $userid,'password' 一 $password,'mobilenumber' 

=> $mobilenumber,'content' => $content,'msgtype' => $msgtype))” 表 示 向 Web Service 传递 的 参数 。 


全 注意 : 在 进行 call() 方 法 中 的 参数 传递 时 ， 必 须 是 以 数组 的 形式 进行 传递。 


9.8.4 单元 测试 


在 完成 短信 发 送 模块 的 设计 后 ， 为 保证 程序 正常 运行 ， 一 定 要 对 模块 进行 单元 测试 。 单 元 测试 在 
程序 开发 中 非常 重要 ， 只 有 通过 单元 测试 才能 发 现 模 块 中 的 不 足 之 处 ， 才 能 及 时 地 弥补 程序 中 出 现 的 
错误 。 下 面 将 对 发 送 短信 模块 中 出 现 的 错误 进行 分 析 。 

在 短信 发 送 页 面 中 完成 信息 的 添加 之 后 ， 单 击 “提交 ”按钮 ， 其 运行 结果 如 图 9.41 所 示 。 

| http://127. 0.0. /Tsoft/ oyke/ Sond 3h2 -|e| EE 
文件 中 编辑 EE) 查看 WW 收 着 内 工具 C) 帮助 | 慰 


地 址 @) | 钻 http: /7127. 0.0 1/Tsoftyaylee/sene 了 | 图 等 到 | 钴 接 > 


Fatal error: Class ”soapclient”mnot found in 
F:\webpage\Isoft\qykzxz\send.php on line 22 


居 完 毕 [ 量 Internet 


图 9.41 ”发送 短信 的 错误 运行 结果 
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根据 错误 信息 中 的 提示 ， 发 现 是 程序 中 没有 找到 soapclient 这 个 类 ， 查 找到 send.php 文件 中 的 第 
22 行 ， 发 现 是 在 程序 中 没有 调用 nusoap.php 文件 ， 从 而 导致 没有 找到 soapclient 类 。 对 该 错误 进行 修 
改 , 将 nusoap.php 文件 复制 到 程序 的 主 目录 下 进行 保存 , 并 通过 inlcude0) 函 数 调用 nusoap/lib/nusoap.php 
类 文件 ， 重 新 保存 程序 代码 ， 短 信 发 送 成 功 。 


9.9 ”连接 邮件 接口 模块 的 设计 


9.9.1 连接 邮件 接口 模块 概述 


在 本 项 目 中 邮件 收发 功能 是 通过 imap 电子 邮件 系统 函数 来 完成 的 ， 所 以 在 开发 程序 之 前 要 将 
php.ini 文件 中 Dynamic Extensions 模块 内 “;extension=php_imap.dll” 前 的 “;” 去 掉 , 然后 重新 启动 Apache 
服务 器 。 

连接 邮件 接口 模块 的 主要 功能 是 与 指定 的 POP3 服务 器 建立 连接 并 实现 用 户 身份 验证 ， 其 运行 结 
果 如 图 9.42 所 示 。 


服务 器 : |192. 168.1. 42 
邮 箱 : jTsoft@sina com 


窗 码 : |@@9 


| 登录 | | 重 杜 | 


图 9.42 邮件 服务 器 登录 页 面 
全 注意: 在 实现 邮件 收发 功能 之 前 首先 要 在 POP3 服务 器 中 创建 一 个 新 邮箱 Tsoft@sina.com， 密 码 为 
111， 用 于 登录 到 服务 器 。 
9.9.2 ”连接 邮件 接口 模块 技术 分 析 
在 连接 邮件 接口 模块 的 设计 中 ， 主 要 应 用 的 是 imap 电子 邮件 系统 函数 中 的 imap_open() 函 数 ， 通 
过 该 函数 实现 与 IMAP 服务 器 建立 连接 。imap_open0 函 数 的 语法 如 下 : 
Tesource imap_open(string mailbox, string username, string password [,int options [,int n_retries]]) 


imap_open() 函 数 的 参数 说 明 如 表 9.10 所 示 。 


RS 
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表 9.10 imap_open() 函 数 的 参数 说 明 


参数 说 了 明 
mailbox 必 选 参数 。 服 务 器 地 址 
USemame 必 选 参数 。 用 户 账 号 
password 必 选 参数 。 用 户 密码 
options 可 选 参数 。 该 参数 取 值 及 说 明 如 表 9.11 所 示 
int n_retries 可 选 参数 。 试 图 与 IMAP 服 务 器 建立 连接 的 最 大 连接 数 
表 9.11 options 参数 的 说 明 
参数 取 值 说 明 
OP READONLY 打开 链接 使 用 只 读 状 态 
OP _ ANONYMOUS 匿名 读 取 NNTP 服 务 器 ， 不 使 用 newsrc 文 件 
OP_ HALFOPEN 只 与 IMAP 或 NNTP 服 务 器 链接 ， 不 打开 邮箱 
CL_EXPUNGE 关闭 链接 时 自动 清除 邮箱 中 的 信件 


全 注意 : 使 用 imap_open() 函 数 连 接 邮件 服务 器 时 ， 在 Intemet 和 局 域 网 上 连接 邮件 服务 器 有 所 不 同 。 
例如 在 Intemet 上 应 用 imap_open() 函 数 连 接 163 的 邮件 服务 器 ， 并 且 用 户 的 邮箱 地 址 为 
“mr***(@163.com”， 密 码 为 123456， 则 imap_open() 函 数 的 格式 为 : 
$mbox=imap_open("{pop3.163.com:110/pop3}"， "mr***","]123456"); 
如 果 用 户 在 局 域 网 上 建立 pop3 服务 器 ， 并 且 服 务 器 的 IP 为 192.168.1.9， 在 POP3 服务 器 上 建立 的 邮箱 为 
mingrisoft@mingrisoft.com， 密 码 为 123456， 则 imap_open() 函 数 的 格式 为 : 
$mbox=imap_open("{192.168.1.9:110/pop3}","mingrisoft(@mingrisoft.com","123456"); 


9.9.3 ”连接 邮件 接口 模块 的 实现 过 程 


连接 邮件 接口 模块 通过 mail.php 和 mail_user.php 两 个 文件 来 完成 。 首 先 通 过 mail.php 文件 创建 一 
个 表单 ， 提交 服务 器 的 IP 地 址 、 邮 箱 名 称 和 密码 到 mail_userphp 文件 中 ， 然 后 在 mail_user.php 文件 中 
应 用 imap_open() 函 数 实现 登录 邮箱 的 验证 。mail_user.php 文件 的 关键 代码 如 下 : 

例 程 11 代码 位 置 : 光盘 \TM\09\qykx\mail_userphp 


<?php 
session_start(); // 初 始 化 session 变 量 
$hostname=" {".$_POST[hostname].":110/pop3}"; 1/ 获取 局 域 网 服务 器 的 人 P 地 址 
S$usemame=$_POST[username]; /获取 邮箱 名 称 
$userpwd=$_POST[userpwd]; /获取 邮箱 密码 


© if(!$mbox=@imap_open("$hostname","$usemame","$userpwd")){ /应 用 imap_open 函 数 实现 登录 邮箱 的 验证 
echo "<script>alert(' 登 录 失 败 !");history.back0:;</script>"; 


Yelsef 

session_register("host"); // 定 义 一 个 session 变 量 host 
session_register("user"); // 定 义 一 个 session 变 量 user 
session_register("pwd"); /定义 一 个 session 变 量 pwd 
$_SESSION[host]=$hostname; // 将 session 的 值 赋 给 变量 $hostname 
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$_SESSION[user]=$usemame; /将 session 的 值 赋 给 变量 Susername 
$_SESSION[pwd]=$userpwd; // 将 session 的 值 赋 给 变量 $userpwd 
@ imap_close($mbox); // 美 闭 由 imap_open0 函 数 所 返回 的 连接 标识 
echo "<script>window.location.href='indexs.php?lmbs= 登 录 ';</script>"; 
h 
> 
< 代码 贴 十 


@ imap_open(0): 实现 登录 邮箱 的 验证 ， 有 关 该 函数 的 详细 讲解 请 参考 连接 邮件 接口 技术 分 析 中 的 内 容 。 
@ imap_close(): 关闭 由 imap_open() 函 数 所 返回 的 连接 标识 。 


bool imap_close( resource imap_stream [,int flag] ) 


imap_stream 为 必 选 参数 ， 是 imap_open() 函 数 与 服务 器 成 功 建立 连接 后 所 返回 的 连接 标识 。flag 为 可 选 参数 ， 如 果 
将 该 参数 设置 为 CL EXPUNGE， 则 在 断 开 与 服务 器 的 连接 同时 删除 所 有 带 有 连接 标记 的 邮件 。 


9.10 ”接收 邮件 模块 设计 


9.10.1 接收 邮件 模块 概述 
在 邮件 接收 模块 中 主要 实现 的 是 从 服务 器 中 读 取 邮 件 的 内 容 ， 并 且 将 内 容 输出 到 页 面 中 。 在 接收 


邮件 模块 中 输出 邮件 的 内 容 ， 对 邮件 进行 分 页 显示 ， 而 且 可 以 对 指定 的 邮件 执行 删除 和 查看 操作 。 运 
行 结果 如 图 9.43 所 示 。 


企业 快 信 V1.0 


企业 快 信 欢 迎 您 t 当前 登录 用 户 : Tseft 连接 短信 “| 连接 邮件 | 修改 密码 | 帮助 | 退出 系统 


| 欢迎 9 >》 导 航 区 j 了 欢迎 : 欢迎 您 登录 邮件 收发 管理 系统 。 


,发 件 箱 Di 
, 收 件 箱 选择 邮件 主题 发 件 人 发 件 时 间 大 小 Os 
查找 邮件 5) swt zzz70sing com 2007-12-29 10:4 2.37 到 


本] # 东 邮件 ! 封 每 页 呈 示 10 封 第 1 页 / 共 ! 页 ) 1 


9.43 ”接收 邮件 模块 的 运行 结果 


SS 
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9.10.2 ”接收 邮件 模块 技术 分 析 


在 接收 邮件 模块 中 主要 应 用 的 是 imap_check() 函 数 、imap_search() 函 数 和 imap_headerinfb() 函 数 ， 
其 中 通过 imap_checkO 函 数 获取 连接 id， 并 返回 包含 当前 邮箱 信息 的 对 象 ， 包 括 邮件 数目 ， 通 过 
imap_search() 函 数 搜寻 指定 标准 的 信件 ;通过 imap_headerinfo0) 函 数 获取 某 信 件 的 标 头 信息 。 

imap_check() 函 数 的 语法 格式 如 下 : 

object imap_check(resource imap_stream) 

参数 imap_stream 为 imap_open() 函 数 成 功 连接 上 邮件 服务 器 后 所 返回 的 连接 标识 。 该 函数 返回 对 

象 可 以 调用 的 属性 说 明 如 表 9.12 所 示 。 
表 9.12 imap_check() 函 数 返 回 对 象 可 调用 的 属性 说 明 


属 性 名 说 ”了 明 

Date 根据 RFC2822 时 间 格 式 所 返回 的 系统 当前 时 间 

Driver 返回 邮箱 所 使 用 协议 的 名 称 ， 包 括 POP3、IMAP 和 NNTP 
Mailbox 返回 邮箱 的 名 称 

Nmsgs 返回 邮箱 中 邮件 的 个 数 

Recent 返回 最 近 收 到 邮件 的 数目 


imap_search() 函 数 的 语法 格式 如 下 : 
array imap_search(resource imap_stream, string criteria[, int options [,string charset]]) 
imap_search() 函 数 的 参数 说 明 如 表 9.13 所 示 。 
表 9.13 imap_search() 函 数 的 参数 说 明 


imap_open() 函 数 与 服务 器 成 功 建立 连接 后 所 返 


criteria 指定 查询 的 条 件 
为 SE_UID 值 
指定 邮件 所 采用 的 字符 集 


imap_headerinfo0 函 数 是 imap_header0 函 数 的 别名 ，imap_headerinfo0) 函 数 的 用 法 与 imap_header0 函 
数 的 用 法 是 相同 的 ， 这 里 只 对 imap_header() 函 数 进行 详细 的 介绍 。imap_header() 函 数 的 语法 格式 如 下 : 
object imap_header(int imap_stream,int msg_number,int [fromlength],int [subjectlength],string [defaulthost]); 
imap_header() 函 数 的 参数 说 明 如 表 9.14 所 示 , 该 函数 返回 对 象 可 以 调用 的 属性 说 明 如 表 9.15 所 示 。 
表 9.14 ”imap_header() 函 数 的 参数 说 明 


参数 说 阴 
imap stream 必 选 参数 。imap_open() 函 数 与 服务 器 成 功 建立 连接 后 所 返回 的 连接 标识 
msg number 必 选 参数 。 邮 件 号 
fromlength 必 选 参数 。 指 定 发 件 人 地 址 长 度 
subjectlength 必 选 参数 。 指 定 主题 长 度 
defaulthost 必 选 参数 。 指 定 默 认 主机 号 


忆 
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表 9.15 imap_header() 函 数 返回 对 象 可 调用 的 属性 说 明 
属 性 值 说 了 明 
Answered 判断 邮件 是 否 已 经 回复 ， 是 则 返回 A， 否 则 返回 空 
bcc 返回 与 Bcc 有 关 的 的 对 象 数组 
becaddress 返回 密 送 人 地 址 
ce 返回 与 Cc 有 关 的 的 对 象 数 组 
ccaddress 返回 抄 送 人 地 址 
date 邮件 被 创建 的 时 间 
Date 与 date 用 法 相同 
Deleted 判断 邮件 是 否 被 打上 删除 标记 ， 是 则 返回 D， 否 则 返回 空 
from 返回 与 发 件 人 信息 有 关 的 对 象 数组 
fromaddress 发 件 人 地 址 
Msgno 返回 邮件 号 
Recent 如 果 是 最 近 的 邮件 并 且 已 经 查看 了 则 返回 R， 否 则 返回 空 
Size 返回 邮件 的 大 小 
Subject 返回 邮件 主题 
subject 与 Subject 用 法 相同 
to 返回 与 收 件 人 有 关 的 对 象 数组 
toaddress 返回 收 件 人 地 址 
Unseen, 如 果 邮 件 已 经 被 查看 则 返回 U， 和 否则 返回 空 值 


在 接收 邮件 模块 中 首先 通过 imap_open() 函 数 来 


到 服务 器 ， 然 后 应 用 imap_check0 函 数 获取 


imap_open() 函 数 成 功 连接 后 返回 的 连接 标识 ， 根 据 获取 到 的 连接 标识 ， 通 过 imap_search() 函 数 搜寻 指 
定 标准 的 信件 , 应 用 imap_headerinfo0 函 数 获取 某 信件 的 标 头 信息 , 最 后 通过 分 页 技术 将 获取 到 的 邮件 
信息 进行 输出 。 程 序 的 关键 代码 如 下 : 
连接 邮件 服务 器 、 创 建 一 个 分 页 技术 ， 输 出 邮件 中 信息 的 关键 代码 如 下 : 
例 程 12 ”代码 位 置 ， 光盘 \TM\09\qykx\lookmail.php 


<?php session_start(); 

$hostname=$_SESSION[host]; 
$username=$_SESSION[user]; 
$userpwd=$_SESSION[pwd]; 


// 初 始 化 session 变 量 


/获取 表单 中 提交 的 服务 器 卫 


/获取 用 户 名 
/获取 密码 


/本 素来 丰 术 丰 相 术 本本 用 ipam_open 函 数 ， 实 现 登录 服务 器 的 验证 ** 下 六 站 / 
if(!$mbox=(@imap_open("$hostname","$usemame","$userpwd")){ 


echo "<script>alert(' 登 录 超时 ， 请 重新 登录 !");history.back();</script>"; 


exit; 
} 
> 


<?php 
$check = imap_check($mbox); 
$sum=$check->Nmsgs; 


Print_r(imap_search($mbox,"SEEN")); 


if($sum<=0){ 
> 


/省 略 了 部 分 代码 


/获取 imap_open 函 数 返 
/将 连接 标识 赋 给 变量 


四 


的 连接 标识 


/根据 连接 标识 查找 指定 标准 的 信件 


// 判 断 当 返回 值 为 空 时 输出 如 下 内 容 
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<tr><td height="25" colspan="5" align="center"> 暂 无 邮件 </td></tr> 
<?php 
jelsef // 判 断 当 返回 值 不 为 空 时 执行 下 面 的 内 容 
/* 编 写 一 个 分 页 技术 ， 用 于 分 页 显示 邮件 信息 类 
这 $_GET[page] 一 "" | is_numeric($_ GET[page] 一 包 lse)){ /判断 当 变 量 Spage 的 值 不 存在 或 为 空 时 


S$page=1; /定义 变量 $page 的 值 为 1 
jelsef 
Spage=$_GET[page]; // 如 果 不 为 空 ， 则 定义 $page 值 为 当前 变量 值 
} 
Spagesize=10; // 定 义 变量 $pagesize 的 值 为 10 
if($sum%S$pagesize=—0){ // 对 邮件 信息 进行 分 页 ， 每 页 显示 10 条 
S$totalpage=$sum/$pagesize; /定义 变量 $totalpage 输 出 共有 几 页 信息 
jelsef 
S$totalpage=ceil($sum/$pagesize); // 对 分 页 进行 取 整 
} 
Sfrompage=($page-1)*$pagesizet+1; // 定 义 $frompage 每 页 的 第 一 条 记录 
S$topage=$frompage+$pagesize; // 定 义 $toppage 表 示 每 页 的 最 后 一 条 记录 
这 ($sum-$topage)<0){ 
S$topage=$sum+1; 
for($i=$frompage;Si<$topage; $i++){ // 应 用 for 循 环 语句 实现 页 面 跳 转 
S$obj=imap_headerinfo($mbox,$i); 1/ 获取 邮件 的 标 头 信息 
Re #/ 


9.10.3 ”查看 邮件 的 实现 过 程 


查看 邮件 的 功能 主要 通过 imap_header() 函 数 、imap_fetchbody() 函 数 和 imap_fetchstructure() 函 数 实 
现 ， 其 运行 结果 如 图 9.44 所 示 。 


| 城 通 97 区， 「y 欢迎 : 欢迎 您 委 录 邮件 收发 管理 系统 。 
TT 


发 翌 箱 

收 隆 箱 时 间 : 。 2007-12-29 10:4:53 
Ee 发 件 人 : 。 zzzzasina com 

发 送 记录 收 件 人 :zzzzasina com 


刷新 主 题 : 。 程序 员 式 
附 件 : 


9.44 查看 邮件 的 运行 结果 
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其 中 imap_header(0 函 数 已 经 在 技术 分 析 中 详细 讲解 过 ， 这 里 主要 对 imap_fetchbody0 函 数 和 
imap_fetchstructure() 函 数 进行 详细 的 讲解 。 


imap_fetchbody() 函 数 用 于 获取 邮件 指定 部 分 的 内 容 ， 其 语法 格式 如 下 : 
string imap fetchbody(resource imap_stream,int msg_number,string part_number [,int options]) 
imap_fetchbody(O) 函 数 的 参数 说 明 如 表 9.16 所 示 。 
表 9.16 imap_fetchbody() 函 数 的 参数 说 明 


imap_stream 必 选 参数 。imap_open() 函 数 与 服务 器 成 功 建立 连接 后 所 返回 的 连接 标识 
msg_number | 必 选 参数 。 邮 件 号 

part number | 必 先 参数。 指定 邮件 部 分 号 

options 可 选 参数 。 


imap_fetchstructure0 函 数 用 于 获取 邮件 的 结构 。 其 语法 格式 如 下 : 
object imap_fetchstructure(resource imap_stream .int msg_number[ ,int options]) 
imap_fetchstructure() 函 数 的 参数 说 明 如 表 9.17 所 示 。 
表 9.17 imap_fetchstructure() 函 数 的 参数 说 明 


imap_stream 必 选 参数 。imap_open() 函 数 与 服务 器 成 功 建立 连接 后 所 返 


必 选 参数 。 邮 件 号 


通过 上 述 3 个 函数 的 合理 应 用 ， 就 可 以 轻松 地 完成 邮件 的 查看 功能 。 首 先 与 邮件 服务 器 建立 连接 ， 
并 根据 连接 标识 和 ID 返回 邮件 标 头 信息 ， 代 码 如 下 : 
例 程 13 ”代码 位 置 ， 光盘 \TM\09\qykx\lookmailinfo.php 


<?php session_start(); // 初 始 化 session 变 量 
$hostname=$_SESSION[host]; 1/ 获取 表单 中 提交 的 服务 器 人 Pp 
$username=$_SESSION[user]; // 获 取 用 户 名 
$userpwd=$_SESSION[pwd]; /获取 密码 


// 应 用 ipam_open 函 数 ， 实 现 登录 服务 器 的 验证 
if(!$mbox=(@imap open("$hostname","$usemame","S$userpwd")){ 


echo "<script>alert(' 登 录 超时 ， 请 重新 登录 !");history.back();</script>"; 


exit; 
’ 
$id=$_GET[id]; /获取 ID 的 值 
S$obj=@imap_header( $mbox,$id); // 根 据 imap_open 函 数 返 回 的 连接 标识 和 ID 的 值 来 获取 邮件 标 头 信息 
> 


然后 根据 获取 的 邮件 标 头 信息 ， 输 出 邮件 的 发 送 时 间 、 发 件 人 、 收 件 人 和 邮件 的 主题 ， 代 码 如 下 : 


RS 
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例 程 14 ”代码 位 置 ， 光盘 \TM\09\qykx\lookmailinfo.php 


<?php 
/获取 邮件 发 送 的 时 间 
© $array=@getdate(strtotime($obj->date)); 
echo 
S$array[year]."-".$array[mon]."-".$array[mday]."&nbsp;".$array[hours].":".$array[minutes].":".$array[seconds]; 
?> 
<2php echo $obj->fromaddress; /获取 发 件 人 2> 
<?php echo $obj->toaddress; /获取 收 件 人 > 
<?php ”// 获 取 邮 件 的 主题 
四 if(strtolower((@substr($obj->Subject,0,10))=—strtolower("=?gb2312?B")) 
@ echo base64 decode(substr($obj->Subject,11,(strlen($obj->Subject)-13))); 
else 
echo $obj->Subject; 
?> 
< 代码 贴 十 


@ getdate(): 获取 日 期 和 时 间 人 信息。 返回 一 个 根据 timestamp 得 出 的 包含 有 日 期 信息 的 结合 数组 。 如 果 没 有 给 出 时 
间 稚 则 认为 是 当前 本 地 时 间 。 

@ strtolower(): 将 字符 转换 为 小 写字 母 。 

@ base64_decode(): 对 使 用 MIME base64 编码 的 数据 进行 解码 。substr(0): 从 指定 的 字符 串 中 按照 指定 的 位 置 截取 
一 定 长 度 的 字符 。strlen() 获 取 指定 字符 串 的 长 度 。 


最 后 获取 邮件 中 附件 的 名 称 和 邮件 的 内 容 ， 并 且 设 置 下 载 附件 的 超 链接 ， 代 码 如 下 ， 
例 程 15 ”代码 位 置 ， 光盘 \TM\09\qykx\lookmailinfo.php 


<?php 

/和 半球 闪 闪闪 闪闪 闪闪 站 补 大 了 了 付 人 -名 有人 环宇 束 束 罕 束 末 环 束 于 束 末末 表 表 素 六 / 

$structure= (Wimap_fetchstructure($mbox,$id); // 获 取 邮 件 的 结构 ， 输 出 附件 的 名 称 
$array=$structure->parts; 


if(($array[1]->dparameters[0]->value)!=""){ 
S$filename=$array[1]->dparameters[0]->value; 


jelse{f 
$filename=$array[1]->description; 
} 
if(strtolower(substr($filename,0,10))=—strtolower("=?gb2312?B")) 
echo base64_decode(substr($filename,11,(strlen($filename)-13))); // 从 信息 中 截取 附件 的 名 称 
else 
echo $filename; /| 输出 附件 名 称 
> 


<!- 设 置 下 载 附件 的 超 链接 -> 
<td width="61"><a href="down.php?id=<?php echo $id;?>" class="a1">( 下 载 附件 )</a></td> 


< -一 > 

<?2php 

Yad 玉 素 米 玉 六 闪闪 这 六 六 六 六 闪闪 六 兴 当 兴 兴 六 率 率 闵 率 六 六 六 闪 太 本 六 站 站 下 友 了 四 5 件 - 内 容 于 村 六 下 六 于 六 六 玉 六 率 六 六 六 六 六 六 六 率 六 六 六 闪 六 率 率 闪闪 六 六 闪闪 $f 
include_once("function.php"); /调用 该 文件 实现 特殊 字符 替换 


/应 用 imap_fetchbody 函 数 获取 邮件 指定 部 分 的 内 容 
if(unhtml(imap base64(@imap fetchbody($mbox,$id,1)))—""){ 
echo unhtml((@imap_fetchbody($mbox.,$id, 1)); 


A 
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Yelsef 
echo unhtml(imap_base64(imap_ fetchbody($mbox,$id,1))); 


} 
?> 


9.10.4 删除 邮件 的 实现 过 程 


删除 邮件 功能 的 实现 应 用 到 imap_open0 函数 、imap_delete0 函数 、imap_close0 函数 和 
imap_expunge() 函 数 。 其 中 主要 应 用 的 是 imap_delete() 函 数 ， 为 指定 的 邮件 打上 删除 标记 ， 应 用 
imap_expunge() 函 数 删 除 所 有 带 有 删除 标记 的 邮件 。 

imap_delete() 函 数 为 指定 的 邮件 打上 删除 标记 ， 然 后 应 用 imap_expunge() 函 数 或 者 imap_close() 函 
数 实现 邮件 的 物理 删除 。 语 法 格式 如 下 : 

bool imap_delete(int imap_stream,int msg_number [,int options]) 


imap_delete() 函 数 的 参数 说 明 如 表 9.18 所 示 。 
表 9.18 imap_delete() 函 数 的 参数 说 明 


必 选 参数 。imap_open0 函 数 与 服务 器 成 功 建立 连接 后 所 返回 的 连接 标识 


msg_number 必 选 参数 。 邮 件 号 


imap_expunge() 函 数 删除 所 有 带 有 删除 标记 的 邮件 。 其 语法 格式 如 下 : 

bool imap_expunge(resource imap_stream) 

参数 imap_stream 为 imap_open() 函 数 成 功 连接 上 服务 器 后 的 返回 值 。 

删除 邮件 功能 的 实现 主要 通过 lookmail.php 和 delmail.php 文件 来 完成 ， 首 先 在 lookmail.php 文件 中 
创建 一 个 表单 , 设置 复 选 框 , 用 来 选择 要 删除 的 邮件 , 创建 “删除 ”按钮 , 将 复 选 框 的 值 提交 到 delmail.php 
页 中 ; 在 delmail.php 页 中 根据 表单 中 提交 的 值 ， 应 用 imap_delete0 函 数 为 指定 的 邮件 打上 删除 标记 ， 最 
后 应 用 imap_expunge() 函 数 删 除 所 有 带 有 删除 标记 的 邮件 。 其 中 delmail.php 文件 的 关键 代码 如 下 : 

例 程 16 ”代码 位 置 ， 光盘 \TM\09\qykx\delmail.php 


<?php session start(); // 初 始 化 session 变 量 
$hostname=$_ SESSION[host]; // 获 取 表 单 中 提交 的 服务 器 IP 
$username=$_ SESSION[user]; // 获 取 用 户 名 
Suserpwd=$_SESSION[pwd]; // 获 取 密 码 


// 应 用 ipam_open 函 数 ， 实 现 登 录 服务 器 的 验证 
if(!$mbox=(@imap open("$hostname","$usemame","S$userpwd")){ 
echo "<script>alert(' 登 录 超时 ， 请 重新 登录 !");history.back();</script>"; 


exit; 
, 
$i=0; // 定 义 变量 $i=0 
while(list($name,$value)=each($_POST)){ // 应 用 list 函 数 获取 表单 中 提交 的 值 ， 应 用 while 语 句 循环 输出 list 函 
数 返 回 的 值 


Sm 
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ifis_numeric($value 六 -tmue)f /判断 Svalue 的 值 是 否 为 真 
$i+=$value; 
if(!@imap_delete( $mbox,$value)){ // 根 据 $value 的 值 和 连接 标识 为 指定 的 邮件 打上 删除 标记 
echo "<script>alert(' 删 除 失败 1");history.back();</script>"; 


exit; 
} 
} 
if($i—0){ // 判 断 当 $i=0 时 执行 下 面 的 内 容 
echo "<script>alert(' 请 选择 要 删除 的 邮件 !");history.back();</script>"; 
imap_close($mbox); // 关 闭 由 imap_open() 函 数 所 返回 的 连接 标识 
exit; 
jelsef 
imap_expunge($mbox); // 判 断 $i 不 等 于 0 时 执行 imap_expunge， 删 除 打上 删除 标记 的 邮件 
imap_close($mbox); // 关 闭 由 imap_open() 函 数 所 返回 的 连接 标识 


echo "<script>window.location.href="indexs.php?lmbs= 删 除 '</script>"; 
} 
> 


9.10.5 下 载 附件 的 实现 过 程 


在 下 载 附件 模块 中 同样 是 应 用 imap_open() 函 数 、imap_header() 函 数 、imap_fetchbody() 函 数 和 
imap_fetchstructure() 函 数 来 实现 。 有 关 这 些 函 数 的 详细 讲解 请 参考 前 面 的 内 容 ， 这 里 不 青 次 述 。 下 载 附 
件 模 块 的 运行 结果 如 图 9.45 所 示 。 


OiYe Kun Xn Vio 


业 快 信 V1.0 


打开 四 | 。 保 齐名 
© 


9.45 下载 附件 模块 的 运行 结果 


下 载 附件 功能 的 实现 从 查看 邮件 页 面 中 的 下 载 附 件 超 链接 开始 ， 在 超 链接 中 设置 一 个 变量 id， 作 
为 指定 附件 的 唯一 标识 ， 该 超 链接 链接 到 down.php 文件 ， 在 该 文件 中 完成 对 指定 附件 的 下 载 。 关 键 代 


人 码 如 下 : 
“451. g 
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例 程 17 ”代码 位 置 ， 光盘 \TM\09\qykx\down.php 


<2php session start(); // 初 始 化 session 变 量 
$hostname=$_SESSION[host]; /获取 表单 中 提交 的 服务 器 趾 
S$username=$_ SESSION[user]; /获取 用 户 名 
$userpwd=$_SESSION[pwd]; /获取 密 码 


/应 用 ipam_open 函 数 ， 实 现 登录 服务 器 的 验证 
©@ ifl$mbox=@imap_open("$hostname","Susername","Suserpwd"))f 
echo "<script>alert(' 登 录 超 时 ， 请 重新 登录 !);history.back();</script>"; 


exit; 
} 

@ $structure=imap_fetchstructure(S$mbox,S$id); // 根 据 提交 的 变量 ID 获 取 指定 邮件 的 结构 
S$array=$structure->parts; /将 邮件 结果 的 信息 赋 给 数组 Sarray 
if(($array[1]->dparameters[0]->value)!="")!{ // 判 断 数 组 中 指定 的 数据 是 否 为 空 

$filename=$array[1]->dparameters[0]->value; // 将 文件 的 名 称 赋 给 变量 $filename 
jelsef 


$filename=$array[1]->description; 
} 
if(strtolower(substr($filename,0,10))=—strtolower("=?gb2312?B")) // 对 文件 的 名 称 进行 截取 
$filename=base64_decode(substr($filename,11,(strlen($filename)-13))); // 对 文件 的 名 称 进行 截取 ， 并 进行 解码 
header("Content-type:application/octet-stream"); 
header("Accept-ranges:bytes"); 
header("Accept-length:100"); 
header("Content-Disposition:attachment;filename=". $filename.""); 


目 $text-imap_fetchbody($mbox,$id,2); // 根 据 提供 的 ID， 获 取 邮 件 第 2 部 分 的 内 容 
echo imap_base64($text); // 对 base64 编 码 的 文本 进行 解码 
imap_close($mbox); /关闭 由 imap_open() 函 数 记 返 回 的 连接 标识 
exit; 
es 

Ah 代码 贴 二 


@ Qimap_open(): 与 IMAP 服务 器 建立 连接 。 
@ imap_fetchstructure(): 获取 邮件 的 结构 。 语 法 如 下 : 


object imap_fetchstructure(resource imap_stream,int msg_number[,int options]) 


参数 imap_stream: 必 选 参数 ， 创 建 与 服务 器 成 功 建立 连接 后 所 返回 的 连接 标识 ; 参数 msg_number: 指 邮件 号 。 
@ imap_fetchbody0: 获取 指定 邮件 的 指定 部 分 的 内 容 。 


9.11 发 送 邮件 模块 设计 


9.11.1 ”发送 邮件 模块 概述 


发 送 邮件 模块 主要 用 于 邮件 的 发 送 ， 并 且 可 以 实现 邮件 群发 和 添加 附件 的 功能 。 在 实现 邮件 群发 
的 过 程 中 ,添加 收 件 人 的 邮箱 地 址 时 必须 使 用 * 进 行 分 割 ， 否 则 将 不 能 实现 。 发 送 邮 件 模块 的 运行 结果 
如 图 9.46 所 示 。 


Se 
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图 9.46 ”发送 邮 件 模块 的 运行 结果 


9.11.2 ”发 送 邮件 模块 技术 分 析 


邮件 发 送 功能 的 实现 主要 通过 imap_mail_ compose() 函 数 和 imap_mail() 函 数 来 完成 。 下面 详 细 讲 解 
一 下 这 两 个 函数 的 使 用 方法 。 
imap_mail_ compose() 函 数 用 于 创建 一 个 MIME 邮件 。 语 法 格式 如 下 : 
string imap_mail compose(array envelope, array body) 
envelope 为 必 选 参数 。 由 与 邮件 地 址 有 关 的 首部 信息 组 成 , 包括 From、Reply_To、Cc、Bcc、Subject 
等 项 ，body 为 必 选 参数 。 由 有 具体 的 邮件 以 及 与 其 格式 有 关 的 各 种 属性 组 成 。 
imap_mail() 函 数 用 于 发 送 邮 件 ， 语 法 格式 如 下 : 
bool imap_mail(string to, string subject, string message [,string additional_headers [, string cc [,string bcc[,string rpath]]]]) 
imap_mail 0 函数 的 参数 说 明 如 表 9.19 所 示 。 
表 9.19 imap_mail() 函 数 的 参数 说 明 


参 数 说 了 明 
to 必 选 参数 。 收 件 人 地 址 
subject 必 选 参数 。 邮 件 主 题 
message 必 选 参数 。 邮 件 内 容 


可 选 参数 。 邮 件 额 外 首部 信息 

可 选 参数 。 抄 送 人 地 址 

可 选 参数 。 密 送 人 地 址 

可 选 参数 。 用 于 设置 Return-Path 首 部 


additional_headers 
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发 送 邮件 的 实现 过 程 


国 发送 邮件 使 用 的 数据 表 : tb mail 

发 送 邮件 的 实现 过 程 主要 应 用 sendmail.php 文件 和 mail_send.php 文件 。 首 先 通过 sendmail.php 文 
件 创建 一 个 form 表单 ， 用 于 提交 邮件 的 发 件 人 、 收 件 人 、 主 题 、 附 件 和 内 容 信 息 ， 将 该 信息 提交 到 
mail_send.php 文件 中 进行 处 理 。 其 中 使 用 的 form 表单 的 属性 如 表 9.20 所 示 。 


名 称 


form2 


fromuser 


touser 


subject 


upfile 


mailbody 


表 9.20 ”发送 邮件 模块 中 使 用 的 重要 表单 元 素 
元 素 类 型 
i method="post" action="mail_send.php" enctype="multipart/form-data” 
onSubmit="retum chkinput(this) 
class="inputcss" id="fromuser" style="background-color:#e8f4ff " 
onMouseOver="this.style.backgroundColor=# 人 ffFFP" 
onMouseOut="this.style.backgroundColor='#e8f4ff" value="<?php echo 
$_SESSION[user]:?>" size="50" 


class="inputcss" id="touser" style="background-color:#e8f4ff " 


text 


textarea onMouseOver="this.style.backgroundColor=#fffFfP" 
onMouseOut="this.style.backgroundColor=#e8f4ff"> 
class="inputcss" id="subject" style="background-color:#e8f4 人 f " 

text onMouseOver="this.style.backgroundColor 一 #fffffP" 
onMouseOut="this.style.backeroundColor=#e8f4ff" size="50" 

file class="inputcss" id="upfile" size="50" 
rows="15" class="inputcss" id="mailbody" style="BORDER-RIGHT: 
#aaaaaa 1px solid; BORDER-TOP: #aaaaaa 1px solid; OVERFLOW-Y: 
scroll; BORDER-LEFT: #aaaaaa 1px solid; WIDTH: 320px; 
SCROLLBAR-SHADOW-COLOR: #556688; 
SCROLLBAR-ARROW-COLOR: #556688; BORDER-BOTTOM: #aaaaaa 
1px solid; SCROLLBAR-BASE-COLOR: #1C92E2; HEIGHT: 120px" 


textarea 


submit 


全 注意 : 


submit class="buttoncss" id="submit" value=" 发 送 " 


在 添加 收 件 人 地 址 时 ， 可 以 直接 将 地 址 输入 到 文本 框 中 ; 也 可 以 从 右 侧 的 下 拉 菜 单 中 选择 对 
应 客户 或 者 同事 ， 单 击 客户 或 者 同事 的 名 称 来 添加 收 件 人 ， 该 技术 的 实现 方法 已 经 在 系统 信 
息 管理 模块 技术 分 析 中 详细 的 讲解 过 , 这 里 不 再 次 述 。 如果 在 添加 收 件 人 的 邮箱 地 址 时 以 “*” 
来 进行 分 市， 那么 就 可 以 实现 邮件 群发 的 功能 。 


在 mail_send.php 文件 中 对 表单 中 提交 的 数据 进行 处 理 , 从 而 应 用 imap_mail() 函 数 实 现 邮 件 发 送 的 
功能 。 关 键 代 码 如 下 : 
例 程 18 ”代码 位 置 : 光盘 \TM\09\qykx\mail_send.php 


<?php 


了 
Sa 


if($_POST[submit]!(=""){ /判断 提 交 的 值 是 否 为 空 
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$subject=$_POST[subject]: // 著 取 邮 件 主题 
$mailbody=$_POST[mailbody]; /获取 邮件 内 容 
S$envelope["from"]=$_POST[fromuser]: 1/ 获取 发 件 人 


S$partl["type"] =TYPEMULTIPART; 
S$partl["subtype"] = "mixed"; 

S$part2["type"] = TYPETEXT:; 
S$part2["subtype"] = "plain"; 
$part2["encoding"] = ENCBINARY; 
$part2["contents.data"] = "$mailbodymwmnvt"; 


Sfilename = $_FILES['upfile']['name']; // 获 取 上 传 文件 的 真实 名 称 
if($filename!=""){ /判断 上 传 文件 是 否 为 空 
S$file=$_ FILES[upfile][tmp_name']; // 获 取 上 传 文件 的 临时 名 称 
@ sfp=@fopen($file, "r"); // 以 写 的 方式 打开 该 文件 
@ $contents=@fread($fp, @filesize($file)); // 读 取 该 文件 
@ @felose($fp); /关闭 文件 
这 $_FILES[upfile][type]){ // 获 取 上 传 文件 的 类 型 
$mimeType=$_FILES[upfile]['type]; /将 文件 的 类 型 赋 给 变量 SmimeType 
jelsef 
$mimeType ="application/unknown"; 
} 
S$part3["type"] = TYPEAPPLICATION; 
S$part3["encoding"] = ENCBINARY; 
$part3["subtype"] = $mimeType; 
$part3["description"] = $filename; 
$part3["contents.data"] = $contents; 
$body[1] = $partl; 
$body[2] = $part2; 
if($filename!=""){ // 判 断 上 传 文件 不 为 空 
Sbody[3] = $part3; /执行 Spart3 
} 
$message=imap_mail_compose($envelope, $body);// 创 建 一 个 MIME 邮 件 
list($msgheader,$msgbody)=split("\rn\rn",$Smessage,2); /将 文件 中 的 数据 以 \nnwn'" 为 分 割 符 ， 分 割 到 数组 中 
9 $data=trim($_POST[touser]); /去 除 收 件 人 字符 串 中 的 空格 
$datas=explode("*",$data); // 以 * 进 行 分 割 ， 返 回 一 个 数组 
$mail_date=date("Y-m-d H:i:s"); // 获 取 时 间 
© $ip=getenv(REMOTE ADDR); // 著 取 人 P 地 址 
while(list($name,$value)=each($datas)){ // 执 行 list 函 数 读 取 数 组 中 的 数据 ， 并 且 应 用 while 语 句 进行 循环 输出 
$sendes=imap_mail($value,$subject,$msgbody,$Smsgheader); 。 // 执 行 imap_mail() 函 数 实现 邮件 的 发 送 
include_once("conn/conn.php"); // 连 接 数 据 库 ， 将 邮件 的 发 送信 息 存 储 到 数据 库 中 


$sql="insert into 
tb_mail(mail_ip,mail title,mail_formuser,mail touser,mail_date)values(".S$ip.",".$subject.",".$_POST[fromuser].",".$value.™" 
,$mail_ date.™)"; 
$rs=new com("adodb.recordset"); 
S$rs->open($sql,$conn,3,1); 
} 
if($sendes=——true){ 
echo "<script>alert(' 邮 件 发 送 成 功 !"):history.back();</script>"; 
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jelsef 
echo "<script>alert(' 邮 件 发 送 失 败 !");history.back();</script>"; 
| 
es 
外 代码 贴 十 
@ fopen: 打开 某 文件 ， 并 返回 该 文件 的 标识 指针 。 
@ fread: 从 文件 指针 所 指 文件 中 读 取 指 定 长 度 的 数据 。 
@@ fclose: 关闭 指定 文件 标识 指针 所 指 的 文件 。 
@ trim(): 删除 字符 囊 中 首尾 的 空白 或 者 其 他 字符 。 
@ getenv0): 获取 环境 变量 的 值 。 


9.11.4 查看 邮件 记录 的 实现 过 程 
国 查看 邮件 记录 使 用 的 数据 表 : tb_mail 


查看 邮件 记录 实现 的 是 对 发 送 邮 件 的 记录 进行 查看 ， 主 要 就 是 读 取 数据 库 中 存储 的 有 关 邮 件 发 送 
的 记录 信息 。 运 行 结果 如 图 9.47 所 示 。 


二 炳 快 售 V1.0 


企业 快 信 欢 迎 您 ， 当前 登录 用 户 : Tseft 


连接 短信 | 连接 邮件 | 修改 密码 | 帮助 | 退出 系统 


欢迎 ? 六 导入 区 ?欢迎 : 欢迎 您 登录 邮件 收发 管理 系统 。 


,发 和 箱 过 看 部 祥 改 更 记 条 

i 邮件 主题 发 件 人 发 和 时间 收 位 人 

.查找 邮 件 a 测试 ssssQsina con a ssssQsina com 
2007-12-29 


"发送 记 录 。 万 程序 测试 em 
出 陋 || gpft2 条 每 页 显示 10 条 第 1 页 / 共 ! 页 


10:04:53 zzzz@sina. com 


图 9.47 查看 邮件 记录 页 面 的 运行 结果 


查看 邮件 记录 功能 的 实现 主要 应 用 的 sendmail_select.php 文件 , 在 该 文件 中 首先 判断 用 户 是 否 登 录 
邮件 服务 器 ， 如 果 已 经 登录 则 可 以 查看 数据 库存 储 的 有 关 邮 件 发 送 记 录 的 数据 。 首 先 连接 数据 库 ， 然 
后 通过 PHP 的 预定 义 类 com 读 取 数 据 库 中 的 数据 ， 通 过 while 循环 语句 输出 读 取 到 的 数据 ， 并 且 应 用 
分 页 技术 对 数据 信息 进行 分 页 显示 。 程 序 的 关键 代码 如 下 : 

例 程 19 ”代码 位 置 ， 光盘 \TM\09\qykx\sendmail_select.php 
<?php session start(); // 初 始 化 session 变 量 


Rs 
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S$hostname=$_ SESSION[host]:; /获取 表单 中 提交 的 服务 器 耳 
$username=$_SESSION[user]: /获取 用 户 名 
$userpwd=$_SESSION[pwd]; /获取 密码 


/应 用 ipam_open 函 数 ， 实 现 登录 服务 器 的 验证 
if(!$mbox=(@imap_open("$hostname","$usemame","S$userpwd"))!{ 
echo "<script>alert(' 登 录 超时 ， 请 重新 登录 !");history.back();</script>"; 


exit; 
> 
<2php include("conn/conn.php"); // 连 接 数 据 库 
$sql="select * from tb_mail"; // 创 建 查询 语句 ， 读 取 数 据 库 中 邮件 发 送 记 录 数 据 
S$rs=new com("adodb.recordset"); // 应 用 PHP 预 定义 类 COM 
S$rs->open($sql,$conn,3,1); // 执 行 查询 语句 
/** 六 闵 玉 闵 永 六 冰冰 站 半 六 分 页 技术 的 实现 做 准备 功能 ## 相 本 本本 相 本 下 机 本 本 本 可 本 可 
S$rs->pagesize=10; /定义 变量 用 于 分 页 技术 的 实现 
// 判 断 当 前 变量 的 值 是 否 存 在 
if((trim(intval($_GET[page]))=—"")ll(intval($_GET[page])>$rs->pagecount)|l(intval($_GET[page])<=0)){ 
Spage=1; // 如 果 当 前 变量 不 存在 值 ， 则 定义 变量 $page 的 值 为 1 
}else{ 
S$page=intval($_GET[page]); } // 如 果 当 前 变量 存在 值 ， 则 获取 该 值 
if($rs->eof || $rs->bof) { 
2> 
<tr><td height="20" colspan="5" bgcolor="#FFFFFF"><div align="center"> 没 有 信息 ! </div></td></tr> 
<?php Yelsef{ 
S$res->absolutepage=$page; 
$mypagesize=$rs->pagesize; 
/本末 束 来 于 于 来 末 于 来 于 于 刺 素来 于 素 宙 束 守 素来 束 守 囊 来 宙 末 于 本 素 机 机 于 间 束 来 宙 环 于 宁 素 可 于 束 表 | 
while(!S$rs->eof && $mypagesize>0){ // 应 用 while 循 环 语句 输出 数据 库 中 数据 
> 


<tr><td width="20"><input type="checkbox" name="check[]" value="<?php S$fields=S$rs->fields(mail_id);echo 
S$fields->value;?>" /></td> <td width="132" height="25"><div align="center"> 
<?php $fields=$rs->fields(mail_title);echo $fields->value;?></div></td> 
<td><div align="center"> 
<?php $fields=$rs->fields(mail_formuser);echo S$fields->value;?></div></td> 
<td><div align="center"> 
<?php $fields=$rs->fields(mail_date);echo $fields->value;?></div></td> 
<td><div align="center"> 
<?php $fields=$rs->fields(mail_touser);echo S$fields->value;?></div></td> 
</t> 
<?php 
$mypagesize--; 
S$rs->movenext; // 将 查询 语句 的 指针 指向 下 一 条 语句 


用 
?> 


全 注意 : 在 应 用 $rs->open 语句 执行 查询 操作 时 ， 一 次 查询 执行 完成 后 ， 一 定 要 应 用 $rs->movenext 语 
句 将 查询 的 指针 指向 下 一 条 记录 ， 否 则 查询 的 指针 不 会 自动 下 移 ， 执 行 下 一 条 查询 语句 ,将 
一 直 停留 在 当前 位 置 ， 从 而 导致 只 能 输出 一 条 记录 。 
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9.12 ”开发 技巧 与 难点 分 析 


9.12.1 PHP 与 Access 数据 库 的 连接 


在 本 项 目 中 使 用 的 是 Access 数 据 库 , 在 建立 PHP 与 Acess 数 据 库 的 连接 时 使 用 的 是 微软 的 ADODB 
数据 库 驱 动 。 

微软 的 ADODB 数据 库 驱 动 即 ActiveX Data Objects (ADO) ,是 Microsoft 开放 数据 库 应 用 程序 的 
数据 库 访问 技术 。 它 被 用 来 设计 同 新 的 数据 访问 层 OLE DB Provider 一 起 协同 工作 ， 提 供 通 用 数据 访 
问 (Universal Date Access) 。OLE DB 是 一 个 低层 的 数据 访问 接口 ， 用 它 可 以 访问 各 种 数据 源 ， 包 括 
传统 的 关系 型 数据 库 ， 以 及 电子 邮件 系统 及 自 定 义 的 商业 对 象 。ADO 技术 大 大 简化 OLE DB 的 操作 ， 
因为 ADO 封装 OLE DB 程序 中 使 用 的 大 量 COM 接口 ， 所 以 ADO 是 一 种 高 层 的 访问 技术 。 

ADO 技术 基于 通用 对 象 模型 (COM ) ， 它 提供 多 种 语言 的 访问 技术 。PHP 是 通过 预先 定义 类 com 
来 使 用 ADO 方法 操纵 Access 数据 库 的 。 该 类 详细 说 明 如 下 : 


string com::com( string module_name [, string server_name [, int codepage]]) 


其 参数 说 明 如 表 9.21 所 示 。 


表 9.21 预先 定义 类 com 的 参数 说 明 


参数 说 明 


module name | 被 请 求 组 件 的 名 字 或 class-id 

DCOM 服 务 器 的 名 字 

指定 用 于 将 PHP 字 符 串 转换 成 UNICODE 字 符 串 的 代码 页 ， 反 之 亦 然 。 该 参数 的 取 值 有 CP_ACP、 
CP MACCP、CP_ OEMCP、 CP SYMBOL、CP _ THREAD ACP、CP UTF7 和 CP UTFS8 


Server_name 


Codepage 


在 本 项 目 中 PHP 与 Access 数据 库 的 连接 是 通过 conn.php 文件 完成 的 ， 其 中 Access 数据 库 文件 存 
储 在 根 目下 的 data/db_mail_shortnote.mdb 文件 中 。 实 现 PHP 与 Access 数据 库 连接 的 程序 代码 如 下 : 


<?php 

$conn = new com("adodb.connection"); // 应 用 COM 类 

/获取 数据 库 文件 

$connstr="driver={microsoft access driver (*.mdb)}; dbq=". realpath("data/db_mail_shortnote.mdb"); 
$conn->open($connstr); /执行 操作 

> 


在 完成 数据 库 的 连接 后 ， 并 不 能 直接 对 数据 库 进行 查询 、 更 新 和 删除 等 操作 ， 必 须 先 建立 记录 集 。 
代码 如 下 : 


include("conn.php"); // 包 含 数据 库 连 接 文件 
S$rs=new com("adodb.recordset"): // 建 立 记录 集 
S$rs->open("select * 位 om score where sno=".$_POST[sno]."",$conn,3,1); /执行 查询 


上 述 代码 涉及 到 记录 集 游标 的 使 用 ， 以 Srs->open($sqLSconn,A,B) 为 例 ， 参 数 A、B 取 不 同 的 值 使 
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游标 具有 不 同 的 属性 ， 如 表 9.22 和 表 9.23 所 示 。 
表 9.22 参数 A 的 用 法 


A 的 取 值 用 法 
0 只 读 ， 当 前 记录 集 指针 只 能 下 移 
1 只 读 ， 当 前 记录 集 指针 可 自由 移动 
2 可 读 写 ， 当 前 记录 集 指针 可 自由 移动 
3 可 读 写 ， 当 前 记录 集 指针 可 自由 移动 并 可 看 到 新 增 记 录 


表 9.23 参数 B 的 用 法 


B 的 取 值 用 法 
1 默认 锁定 类 型 ， 记 录 集 只 读 ， 不 能 修改 记录 
5 翡 观 锁定 ， 当 修改 记录 时 ， 数 据 提供 者 将 尝试 锁定 记录 以 确保 成 功 地 编辑 记录 ， 只 要 编辑 一 开始 ， 
则 立即 锁定 记录 
3 乐观 锁定 ， 直 到 用 update 方 法 提交 更 新 的 记录 时 才 锁 定 记录 
4 批量 乐观 锁定 ， 允 许 修改 多 个 记录 ， 只 有 调用 update batch 方 法 时 才 锁 定 记 录 


9.12.2 ”邮件 群发 技术 


在 本 项 目 中 ， 不 但 可 以 实现 邮件 的 单独 发 送 ， 而 且 实现 了 邮件 群发 的 功能 。 下 面 对 邮 件 群 发 功能 
的 原理 和 实现 方法 进行 详细 讲解 。 

邮件 群发 的 实现 原理 : 首先 将 邮箱 地 址 添加 到 文本 框 中 ， 并 且 以 “* ”来 分 隔 邮 箱 地址 ， 然 后 将 表 
单 中 的 数据 提交 到 处 理 页 ， 最 后 在 处 理 页 中 获取 文本 框 中 提交 的 邮箱 地 址 数据 ， 获 取 到 的 数据 是 一 个 
以 * 进 行 分 隔 的 字符 串 ， 这 时 应 用 explode() 函 数 对 获取 到 的 字符 串 进行 分 制 ， 以 “* ”为 分 割 符 ， 将 返 
回 一 个 数组 ; 应 用 list0 函 数 读 取 数 组 中 的 元 素 ， 最 后 应 用 while 循环 语句 对 数组 中 的 元 素 进行 输出 ， 
并 执行 邮件 的 发 送 。 

邮件 群发 功能 实现 的 完整 代码 可 以 参考 本 章 中 的 “发 送 邮件 的 实现 过 程 ” 一 节 ， 这 里 只 给 出 实现 
邮件 群发 的 关键 代码 。 


<?php 

if($_POST[submit]!=""){ // 刊 断 提交 的 值 是 否 为 空 

/#* # 洒 小半 站 站 站 半 # 站 # 这 里 省 略 了 部 分 代码 ， 主 要 介绍 如 何 实现 邮件 群发 的 实现 方法 # 相 相 本 相 相 下 本 本本 水 / 
$data=trim($_POST[touser]); /去 除 收 件 人 字符 串 中 的 空格 
$datas=explode("*",$data); // 对 表单 中 提交 的 邮箱 地 址 信息 以 * 进 行 分 割 ， 并 返回 一 个 数组 


店 执 行 list 函 数 读 取 数组 中 邮箱 地 址 数据 ， 应 用 while 语 句 输出 邮箱 地 址 ， 并 在 while 语 句 内 部 执行 邮件 发 送 的 操作 */ 
while(list($name,$value)=each($datas)){ 
$sendes=imap_mail($value,$subject,Smsgbody,$Smsgheader); ” // 执 行 imap_mail() 函 数 实现 邮件 的 发 送 
include_once("conn/conn.php"); /连接 数据 库 , 将 邮件 的 发 送信 息 存 储 到 数据 库 中 
$sql="insert into 
tb mail(mail ip,mail title,mail formuser,mail touser,mail date)values(".S$ip.",".$subject.",".$ POST[fromuser].",".$value.”" 


"$mail date.™)"; 
“459。 乡 
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$rs=new com("adodb.recordset"); 
S$rs->open($sql,$conn,3,1); 


/本 来 于 于 束 束 束 束 束 束 束 于 束 事 于 束 束 呈 训 于 刺 可 于 于 束 可 训 束 市 本 训 训 市 训 训 束 刺 本 于 市 市 字 训 训 市 可 可 市 市 字 事 训 市 字 束 市 囊 束 训 训 市 束 于 于 囊 事 事 束 市 末 事 训 下 束 事 事 事 末 束 /| 


} 


> 


9.13 ”通过 fsockopenl() 函 数 发 送 短信 技术 专题 


实现 短信 发 送 的 方式 很 多 ， 不 但 可 以 使 用 Web Service 技术 来 实现 ， 还 可 以 通过 短信 猫 或 者 
fsockopen() 函 数 来 完成 。 通 过 fsockopen() 函 数 发 送 短信 ， 就 是 采用 socket 编程 的 方式 发 送 短信 。 用 户 
需要 做 的 是 到 移动 、 联 通 等 单位 申请 短信 网 关 和 短信 端口 ， 与 程序 实现 连接 来 发 送 短信 。 

下 面 介绍 fockopen() 函 数 。 该 函数 的 语法 格式 如 下 : 

int fsockopen( string hostname, int port [, int errno [, string errstr [, float timeout]]]) 

fsockopen0 函 数 的 参数 说 明 如 表 9.24 所 示 。 

表 9.24 fsockopen() 函 数 的 参数 说 明 


参 数 说 了 明 

hostname 服务 器 地 址 

port 服务 器 端口 号 

errno 可 省 参数 ， 连 接 服务 器 时 ， 如 果 出 错 ， 则 保存 错误 号 
errstr 可 省 参数 ， 连 接 服务 器 时 ， 如 果 出 错 ， 则 保存 错误 信息 
timeout 可 省 参数 ， 连 接 服 务 器 的 最 大 超时 时 间 


下 面 详细 的 讲解 一 下 通过 socket 编程 实现 短信 发 送 技 术 。 操 作 步 骤 如 下 : 
(1) 创建 一 个 表单 页 socketphp， 用 于 提交 网 关 地 址 、 端 口号 、 用 户 名 、 密 码 、 发 送 受 机 号 码 、 
接收 受 机 号 码 和 短信 内 容 ，socket.php 页 中 表单 的 重要 属性 如 表 9.25 所 示 。 


表 9.25 ”发 送 短信 中 使 用 的 重要 表单 元 素 


名 称 | 元 素 类 型 重要 属性 含义 
forml form method="post" action="socket.php" onsubmit="return chkinput(this)" 表单 
ip text class="inputcss" size="25" 网 关 地 址 


Size="5" class="inputcss" 
usermame text cla nputcess" size="25" 用 户 名 
userpwd | password class="inputcss" size="25" 密码 
telnumber text class="inputcss" size="25" 发 送 手 机 号 码 


接收 手机 号 码 
短信 内 容 


receivenumber | text class="inputcss" size="25" 


content textarea Cols="40" rows="5" class="inputcss" 
class="buttoncss" id="submit" value=" 发 送 " 


Submit 
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(2) 在 socket.php 页 中 通过 $_ POST[ ] 全 局 数组 接收 表单 提交 的 信息 ,最 后 通过 文件 操作 函数 将 短 
信和 发 送出 去 。 关 键 代码 如 下 : 


<?php 

if($ POST[submit]!=""){ 
$smsUID=$_POST[usemame]:; // 短 信 网 关 分 配 的 用 户 名 和 密码 
$smsPWD=$ POST[userpwd]; 
$smsSocket=$ POSTI[id]; // 短 信 网 关 的 人 P 
$smsPost=$_POST[port]; // 短 信 网 关 的 端口 
$fp=(@fsockopen($smsSocket,$smsPost,&$errmno, &S$errstr, $smsTimeout); 
if(!Sfp)!{ 

echo "<script>alert(' 与 短信 网关 连接 失败 1");</script>"; 
Yelse{ // 否 则 登录 到 短信 中 心服 务 器 
fputs($fp,"login\n"); // 将 loginn 写 入 到 文件 $fp 中 


fputs($fp,$smsUID."\n"); 
fputs($fp,$smsPWD."\n"); 


fputs($fp,"\n"); 
$MessageContent=trim($_POST[content]); // 获 取 短信 内 容 
$MobileNo=trim($_POST[telnumber]); // 获 取 电 话 号 码 
SReceiveNo=trim($_POST[receivenumber]); /获取 接收 电话 号 码 
$ServiceType="MFFW": // 计 费 代码 TP0.5 按 条 收费 
S$Priority="0"; // 发 送 优先 级 
; // 代 收费 标志 
/点 播 号 
/短信 失效 时 间 
/定时 发 送 时 间 
$ReportFlag="1"; /状态 报告 
$status="255"; // 都 要 返回 状态 报告 
$MessageType= "TEXT"'; /短信 类 型 ,文本 信息 
$FreeTerminalNo=$MobileNo; // 记 费 手机 号 码 ， 本 实例 采用 收 短信 方 收费 
STargetTerminalNo=$ReceiveNo; // 接 收 方 手 机 号 码 
S$SourceTerminalNo=$MobileNo; // 发 送 方 手 机 号 码 


$Messageld="123"; 

/中 中 于 中 中 于 于 守则 本 半 烛 站 于 业 站 直下 站 有 月 ] 文件 系统 函数 对 信息 进行 编译 并 发 送 间 本 哩 下村 本本 于 中 于 下 于 虽 间 来/ 
print(fgets($fp,4096)); 

print(fgets($fp,4096)); 

fputs($fp,"submit"."\n"); 

fputs($fp,$Messageld."\n"); 

fputs($fp,$FreeTerminalNo."\n"); 

fputs($fp,$SourceTerminalNo."\n"); 

fputs($fp,$TargetTerminalNo."\n"); 

fputs($fph,$ServiceType."\n"); 

fputs($fp,S$MoFlag."\n"); 

fputs($fp,$ReportFlag."\n"); 

fputs($fp,$ExpireTime."\n"); 

fputs($fp,$ScheduleTime."\n"); 

fputs($fp,$MessageType."\n"); 
$MessageContent=str_replace("\r","",str_replace("\n","",$MessageContent)); // 不 能 有 回 车 
fputs($fp,$MessageContent."\n"); 


A 


PHP 项 目 开发 全 程 实录 


fputs($fp,"\n"); 
print("<div align=center> 发 送 成 功 !".SMobileNo." : ".$SMessageContent."</div>"); 


felose($fp); 


通过 socket 编程 发 送 短信 的 运行 结果 如 图 9.48 所 示 。 
通过 socket 编 程 实现 短信 发 送 


图 9.48 socket 编程 发 送 短信 的 运行 结果 


9.14 ”本章 总 结 


本 章 主要 讲解 的 是 企业 快 信 系 统 的 开发 过 程 ， 从 最 初 的 系统 分 析 、 到 系统 的 设计 、 再 到 数据 库 的 
设计 ， 最 后 到 具体 模块 的 创建 。 其 中 在 有 具体 模块 创建 的 过 程 中 针对 系统 信息 管理 模块 、 发 送 短信 模块 、 
连接 邮件 接口 模块 、 接 收 邮 件 模块 和 发 送 邮 件 模块 进行 重点 讲解 ， 并 且 在 其 中 应 用 到 很 多 新 的 技术 和 
技巧 。 例 如 ， 通 过 Web Service 发 送 短信 技术 、 通 过 fsockopen() 函 数 发 送 短信 技术 ， 通 过 imap 电子 邮 
件 系统 函数 发 送 和 接收 邮件 技术 ， 以 及 通过 ADO 实现 PHP 与 Access 数据 库 的 连接 技术 等 。 


Se 
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在 全 球 知识 经 济 和 信息 化 高 速 发 展 的 今天 , 网 络 化 是 企业 发 展 的 趋势 , 21 世纪 
的 人 更 习惯 在 网 站 上 听 音 乐 、 看 电影 ， 所 以 企业 在 同 领域 中 得 到 突飞猛进 的 发 展 ， 
就 必须 借助 网 络 。 

当今 社会 进入 了 一 个 信息 快速 发 展 的 社会 , 在 网 络 世界 浏览 信息 的 同时 也 可 以 
听 听 歌曲 ， 这 样 既 恰 悦 了 身心 ,又 得 到 了 最 新 的 市 场 动 态 ， 由 此 网 络 上 也 出 现 了 很 
多 的 影视 网 站 ， 都 很 受到 欢迎 。 未 来 视听 生活 的 新 空间 ， 也 必然 在 宽带 互联 网 上 开 
启 。VOD 的 概念 已 经 被 越 来 越 多 的 人 所 接受 ， 逐渐 成 为 网 络 发 展 的 必然 趋势 之 一 。 
通过 阅读 本 章 ， 可 以 学 习 到 : 


online 影视 365 类 网 站 的 整体 设计 思路 及 实现 方法 
应 用 <embed> 和 <object> 播 放 影音 文件 

关闭 子 窗 口 时 自动 刷新 父 窗口 

制作 无 边框 的 窗口 

ADODB 介绍 及 使 用 

更 改 数据 库 时 的 注意 事项 


于 于 于 于 于 至 
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10.1 开发 青 


郑 


X XX 影视 有 限 公 司 是 一 家 以 影视 为 主 的 公司 。 为 了 扩大 企业 规模 ， 增 强 企业 的 竞争 力 ， 决 定向 
多 元 化 发 展 ， 计 算 机 技术 、 网 络 通信 技术 、 多 媒体 技术 及 数据 存储 技术 的 飞速 发 展 对 人 类 的 生产 和 
生活 方式 产生 了 很 大 影响 。 网 络 传播 以 其 特有 的 快速 、 高 效 、 便 捷 的 传输 方式 直接 被 人 们 所 接受 。 随 
着 多 媒体 数据 的 存储 、 传 输 和 应 用 技术 的 不 断 成 熟 ， 以 及 宽带 网 络 的 不 断 发 展 ， 我 们 有 理由 相信 宽带 
点 播 一 定 会 成 为 网 络 内 容 创 新 的 重头 戏 。 


10.2 ”需求 分 析 


根据 客户 要 求 及 成 本 核算 ， 本 系统 所 要 实现 的 功能 如 下 : 

网 站 实行 会 员 等 级 管理 ， 分 “普通 会 员 ” 和 “高 级 会 员 ” 两 种 。 

网 站 提供 下 载 功能 和 在 线 视听 功能 ， 不 同 的 会 员 等 级 实现 的 功能 操作 也 不 同 。 

网 站 分 前 台 和 后 台 两 部 分 ， 没 有 权限 ， 用 户 无 法 进入 后 台 进 行 管理 。 

独特 的 点 歌 模块 ， 为 网 站 的 会 员 提 供 点 歌 平 台 。 

前 期 数据 量 比较 少 ， 可 以 使 用 小 型 数据 库 以 节约 成 本 ， 如 果 后 期 数据 量 增 大 ， 则 可 以 更 换 大 
型 数据 库 。 


加 图 图 图 回 


10.3 ”系统 分 析 


10.3.1 系统 目标 


online 影视 365 网 主要 实现 以 下 目标 

回 自 定义 的 鼠标 样式 增强 了 网 站 界面 的 和 谐 性 。 

回采 用 无 边框 窗口 技术 ， 保 障 系统 的 安全 性 。 

回 ”信息 搜索 灵活 、 方 便 。 

回采 用 多 媒体 引用 技术 播放 影音 文件 。 

回 ”网 站 采用 文件 上 传 和 下 载 技术 实现 图 像 、 音 频 、 视 频 文件 的 客户 端 上 传 和 下 载 。 


10.3.2 ”系统 功能 结构 


根据 online 影视 365 网 的 特点 ， 可 以 将 其 分 为 前 台 和 后 人 台 两 个 部 分 设计 。 前 台 主 要 实现 在 线 视听 、 
影视 音乐 上 传 、 影 视 音 乐 下 载 、 在 线 聊 天 和 在 线 点 歌 等 功能 ， 后 台 主 要 用 于 管理 员 对 影视 音乐 目录 、 
数据 信息 和 上 传 日 志 进 行 管理 。 


Se 
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online 影视 365 网 的 前 台 功 能 结构 如 图 10.1 所 示 。 


online 影视 365 网 前 台 


I [ I 
在 线 视听 | [上 传 专区 | [点 歌 专区 | [ 详细 信息 ] [信息 展示 ] | 信息 查询 | | 下载 排行 | [会 员 专区 | [站 长 登录 
| 

| | 

视 | | 音 点 | | 音 || 视 视 视 | | 音 | 会 | 会 后 
在 || 在 | “| 频 || 频 歌 | | 频 | | 频 频 | | 一 | | 高 | “| 据 | | 频 | 员 | 员 | 会 | 会 | | 台 
线 | | 线 | | 数 | | 数 信 | | 信 | | 信 | | 般 | | 级 | | 下 | | 下 | 密 | 资 | 员 | 员 | | 登 
视 | | 观 | | 据 | | 据 息 | | 息 | | 息 息 | | 查 | | 查 | “| 载 | | 载 | 码 | 料 | 注 | 登 | | 录 
听 | | 看 | | 上 || 上 阅 | | 查 | | 查 展 | | 询 | | 询 | “| 排 | | 排 | 找 | 修 | 雪 | 录 | | 管 

传 | | 伟 读 | | 看 | | 看 示 行 | | 行 | 回 | 改 理 


图 10.1 online 影视 365 网 前 台 功 能 结构 图 
online 影视 365 的 后 台 功 能 结构 如 图 10.2 所 示 。 


online 影视 365 网 前 台 


上 传 日 志 管理 


Eh: 
淮 沉 并 岗 砍 
GE 


瞳 囊 薄 涨 泪 否 


添 莹 计 卫 本 上 
溢 式 潭 王 潭 芭 


此 
传 
日 
志 
查 
询 


图 10.2 online 影视 365 网 后 台 功 能 结构 图 
10.3.3 功能 预览 


onlie 影视 365 网 由 多 个 功能 模块 组 成 ， 为 了 让 读者 对 本 系统 有 个 初步 的 了 解 和 认识 ， 下 面 列 出 儿 
个 典型 功能 的 页 面 ， 其 他 页 面 参见 光盘 中 的 源 程序 。 

影视 专区 页 面 如 图 10.3 所 示 , 该 页 面 展 示 所 有 的 视频 信息 及 其 分 类 。 音乐 专区 页 面 如 图 10.4 所 示 ， 
该 页 面 展 示 所 有 的 音频 信息 及 其 分 类 。 
最 新 影视 页 面 如 图 10.5 所 示 ， 该 页 面 用 于 显示 所 有 的 最 新 上 传 的 影视 文件 。 注 册页 面 如 图 10.6 所 
示 ， 该 页 面 显示 了 游客 注册 时 需要 填写 的 昵称 、 密 码 和 个 人 资料 等 相关 内 容 。 


A 
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区 (光盘 \TM\10\online\listphp?action=video) 


| 


图 10.5 最 新 影视 (光盘 \TM\10\online\ listphp) 图 10.6 音乐 专区 (光盘 \TM\10\online\ register.php) 


查询 页 面 如 图 10.7 所 示 , 该 页 显示 简单 查询 所 查 到 的 音频 、 视频 文件 列表 。 高 级 查询 页 面 如 图 10.8 
所 示 。 该 页 面 用 于 模糊 查询 音 、 视 频 文 件 ， 包 含 了 多 个 字段 ， 可 任意 选择 。 


TE 
| 


| 
.2 


图 10.7 简单 查询 (光盘 \TM\10\online\show.php) 


Se 


图 10.8 ”高 级 查询 (光盘 \TM\10\online\high.php) 
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10.3.4 系统 流程 图 


online 影视 365 网 的 系统 流程 图 如 图 10.9 所 示 。 


信息 查看 
信息 查询 ” 一 


上 传记 录 查 看 


图 10.9 online 影视 365 网 的 系统 流程 图 
10.3.5 ”开发 环境 


在 开发 online 影视 365 网 时 ， 该 项 目 使 用 的 软件 开发 环境 如 下 : 
。 服务 器 端 

操作 系统 : Windows Server 2003 。 

服务 器 : Apache 2.0。 

PHP 软件 : PHP 5.0。 

数据 库 : MySQL 5.0。 

MySQL 图 形 化 管理 软件 : PhpMyAdmin-2.5.5。 
开发 工具 : Dreamweaver 8。 

浏览 器 : IE 6.0。 

分 辨 率 ， 最 佳 效果 1024X 768 像素 。 
客户 端 

浏览 器 : 推荐 使 用 IE 6.0 及 以 上 版 本 。 

分 辨 率 : 最 佳 效 果 1024X768 像素 。 


hb 


加 加 六 国峰 加 回国 罗 图 回 


10.3.6 文件 夹 组 织 结构 


online 影视 365 网 包括 前 台 和 后 台 两 部 分 ， 所 以 文件 夹 结构 也 主要 由 两 部 分 组 成 。online 影视 365 


网 的 组 织 结 构图 如 图 10.10 所 示 。 
467 。 乡 
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EB online 影视 365 系 统 根 目录 
| 日 -加 adanin 后 台 管理 系统 目录 
四 加 vm， 后台 数据 库 链 接 文件 目录 
-加 css 后 台 ess 样 式 文件 目录 
辐 inages ~- 后 台 背 且 及 图 标 文件 目录 
针 ine 后 台 自 定义 函数 及 公共 文件 目录 
BB js 后 台 javasceript 脚 本 文件 目录 
ado adodh 库 文件 目录 
com 前 台数 据 库 链接 文件 目录 
ess 前 台 ess 样 式 文件 目录 
images 前 台 背景 及 图 标 目录 
ine 前 台 自 定义 函数 及 公共 文件 目录 
js 前 台 javascript 脚 本 文件 目录 
upfiles UL 上传 文 件 管理 目录 


10.10 online 影视 365 网 的 文件 夹 组 织 结构 图 


10.4 “数据库 设计 


10.4.1 数据 库 分 析 


本 系统 使 用 的 是 MySQL 数据 库 ， 但 使 用 的 是 ado 连接 方式 ， 这 是 为 了 便于 以 后 数据 负担 加 重 后 ， 
可 以 更 改 其 他 数据 库 ， 如 使 用 oracle。 只 要 更 改 数据 库 而 无 须 重 新 编写 源 程序 。 


10.4.2 ”数据库 概念 设计 


通过 需求 分 析 和 功能 上 的 设计 ， 本 系统 规划 出 管理 员 信息 实体 、 会 员 信息 实体 、 视 频 信息 实体 、 
音频 信息 实体 、 视 频 目录 实体 和 音频 目录 实体 。 下 面 给 出 主要 的 实体 及 E-R 图 。 

会 员 信息 实体 包括 注册 用 户 的 详细 个 人 信息 ， 如 果 想 下 载 或 在 线 视 听 ， 则 必须 注册 为 会 员 才 可 以 。 
会 员 信息 实体 E-R 图 如 图 10.11 所 示 。 


10.11 会 员 信息 实体 E-R 
。468 。 
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视频 文件 实体 包括 视频 名 称 、 视 频 图 片 、 视 频 文件 、 主 要 演员 、 导 演 、 发 行商 等 多 项 资料 ， 视 频 
信息 实体 E-R 图 如 图 10.12 所 示 。 

音频 目录 实体 包括 音频 目录 分 类 的 相关 信息 ， 如 目录 名 称 ， 目 录 级 别 、 父 目录 名 称 等 ， 音 频 目 录 
实体 E-R 图 如 图 10.13 所 示 。 


音频 目录 


创建 用 户 
创建 时 间 


图 10.12 视频 信息 实体 E-R 图 图 10.13 音频 目录 实体 E-R 图 


10.4.3 ”数据 库 物 理 结构 设计 


online 影视 365 网 的 数据 库 中 共 包 含 8 个 数据 表 ， 如 图 10.14 所 示 。 


加 服务 器 : localhost ， 号 数据 库 : db_online 
表 类 型 整理 说 明 
tb_account MylISAM gb2312_chinese_ci 会 员 信 息 列表 


tb_audio MylSAM ”gb2312_chinese_ci ”视频 信息 列表 
tb_audiolist MyISAM gb2312_chinese_ci ”视频 目录 列表 
tb_grade MylSAM ”gb2312_chinese_ci ”等 级 限定 列表 
th_manager MylSAM “gb2312_chinese_ci ”管理 员 列表 

tb_register MylSAM gb2312_chinese_ci 点 歌 信 息 列 表 
th_video MylISAM ”gb2312_chinese_ci ”音频 信息 列表 
tb_videolist MylSAM gb2312_chinese_ci ”音频 目录 列表 


图 10.14 db_online 库 中 的 数据 库 列 表 
下 面 来 看 一 下 各 个 表 的 结构 设计 。 
1. tb_account (会 员 信息 列表 ) 
会 员 信息 列表 主要 存储 用 户 的 个 人 信息 ，tb_account 表 的 结构 如 图 10.15 所 示 。 


< 
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图 服务 器 : localhost ， 昌 数据 库 : db_online ， 国 表 :tb_account 
字段 类 型 属性 Nul 球 认 说 明 
记 int(1) 要 自动 篇 号 
name Yarchar(30) ”gb2312_chinese_ci 否 会 员 昵称 
password varchar(30) 。 gb2312_chinese_ci 否 会 员 密码 
question 。 varchar(50) 。 gb2312_chinese_ci 否 密码 提示 问题 
answer varchar(50) gb2312_chinese_ci 否 密码 提示 答案 
realName varchar(30) 9b2312_chinese_ci 否 会 员 真 实 姓名 
numbers varchar(20) gb2312_chinese_ci 否 身份 证 号 
sex varchart10)。 gb2312_chinese_ci 否 会 员 性 别 
age int(4) 再 会 员 年 龄 
job Yarchar(50) gb2312_chinese_ci 理 所 做 工作 
email varchar(100) gb2312_chinese_ci 理 Enail 
address varchar(100) gb2312_chinese_ci 否 联系 地 址 
phone Yarchar(20) ”gb2312_chinese_ci 否 联系 电话 
蚂 varchar(20) 。 gb2312_chinese_ci 理 联系 9 
http varchar(100) gb2312_chinese_cl 理 个 人 主页 
counts int(4) 否 0 上 传 次 数 
grade varchar(10) gb2312_chinese_ci 否 。 普通 会 员 会 员 级 别 
whether varchar(10) gb2312_chinese_cl i 是 否 激活 


图 10.15 会 员 信息 列表 结构 
2. tp_audio( 视 频 信息 列表 ) 
视频 信息 列表 主要 上 传 视频 的 资料 


如 视频 名 称 、 视频 图 片 等 。 tb_audio 表 的 结构 如 图 10.16 所 示 。 


胃 服务 器 : localhost 〉 恒 数据 库 : db_online ， 国 表 :tb_audio 
字段 类 型 整理 尾 性 Null 默认 说 明 
这 int4) 否 自动 编号 
name varchar(100) gb2312_chinese_ci 理 视频 名 称 
picture varchar(200) gb2312_chinese_cl 否 封面 图 片 
sizes varchar(50) gb2312_chinese_ci 否 视频 大 小 
grade varchar(10) gb2312_chinese_cl 否 视频 级 别 
publisher 。 varchart100) 。 gb2312_chinese_ci 否 发 行 公司 
actor varchar(200) 。 gb2312_chinese_ci 否 主要 演员 
director varchar(100) 。 gb2312_chinese_ci 理 导演 
marker varchar(100) gb2312_chinese_ci 否 制 片 
languages varchar(20) gb2312_chinese_ci 否 语种 
type varchar(50) gb2312_chinese_ci 否 类 型 
style varchar(50) gb2312_chinese_ci 否 类 别 
froms varchar(100) 。 gb2312_chinese_ci 否 视频 所 属地 区 
publishTime date 否 发 行 时 间 
remark varchar(1000) gb2312_chinese_ci 否 视频 介绍 
property varchar(20) gb2312_chinese_ci 否 视频 属性 
address varchar(200) gb2312_chinese_ci 否 存储 地 址 
Username varchar(50) gb2312_chinese_ci 理 发 布 人 姓名 
issueDate 。 datetime 再 发 布 时 间 
downTime int(4) 否 0 下 载 次 数 
lastTime datetime 否 最 后 下 载 时 间 
whether varchar(20) gb2312_chinese_c 要 河 加 是 否 为 新 晶 


图 10.16 视频 信息 列表 结构 
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3. tb_audiolist (视频 目录 列表 ) 
视频 目录 列表 主要 是 上 传 视频 所 属 的 类 型 (二 级 目录 ) 及 类 别 〈 一 级 目录 ) 。tb_audiolist 表 的 结 
构 如 图 10.17 所 示 。 


盟 服务 器 : localhost ， 昌 数据 库 : db_online ， 国 表 :tb_audiolist 
宇 段 类 型 整理 尾 性 Null 默认 说 明 
过 int(4) 否 自动 编号 
grade Yarchar(20) gb2312_chinese_ci 否 目录 级 别 
name Yarchar(50) gb2312_chinese_ci 否 目录 名 称 
father Yarchar(50) gb2312_chinese_ci 否 余 级 目录 
userName varchar(30) gb2312_chinese_ci 否 包 建 人 昵称 
issueDate ” datetime 否 创建 时 间 


图 10.17 视频 目录 列表 结构 
4. tb_manager (管理 员 列 表 ) 
管理 员 列 表 主 要 用 于 后 台 管 理 员 的 资料 信息 管理 ， 包 括 管理 员 名 称 、 管 理 员 权限 等 。tb_manager 
表 的 结构 如 图 10.18 所 示 。 


困 服务 器 : localhost ， 马 数据 库 : db_online ， 国 表 :tb_manager 
字段 类 型 整理 尾 性 Null 默认 说 明 
过 int(4) 否 自动 编号 
name varchar(50) gb2312_chinese_ci 否 管理 员 昵 称 
password varchar(50) gb2312_chinese_ci 否 管理 员 密码 
type varchar(50) gb2312_chinese_ci 否 管理 员 类 型 
realName varchar(50) gb2312_chinese_ci 否 真实 姓名 
issueDate datetime 否 创建 时 间 
whether yarchar(50) yb2312_chinese_ci 否 是 否 激活 


图 10.18 管理 员 列表 结构 
5. tb_register (点 歌 信息 列表 ) 
点 歌 信息 列表 主要 存储 等 会 员 用 户 之 间 的 点 歌 祝福 ， 主 要 包括 发 送 人 、 接 收 人 、 和 歌曲 地 址 等 。 
tb_register 表 的 结构 如 图 10.19 所 示 。 


困 服务 器 : localhost 加 数据 库 : db_online ， 国 表 :tb_register 
字段 类 型 整理 尾 性 ”Null 默认 说 明 
过 int4) 否 自动 编号 
name int(4) 否 歌曲 地 址 
fromName varchar(50) gb2312_chinese_ci 否 发 送 人 姓名 
toName varchar(50) gb2312_chinese_ci 否 接收 人 姓名 
remark Yarchar(50) gb2312_chinese_ci 否 备注 
issueDate datetime 否 点 歌 时 间 


10.19 ”点 歌 信息 列表 结构 
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6. tb_video〈 音 频 信 息 列表 ) 
音频 信息 列表 主要 用 于 音频 文件 的 信息 管理 , 如 歌手 、 歌 词 等 。 tb_video 表 的 结构 如 图 10.20 所 示 。 


困 服务 器 : localhost ， 号 数据 库 : db_online ， 国 角 :tb_video 
字段 类 型 整理 尾 性 Null 默认 说 明 

对 int(#) 否 自动 编号 
name Varchar(100) gb2312_chinese_ci 否 音频 名 称 
picture Varchar(200) gb2312_chinese_ci 否 封面 图 片 
actor varchar(100) gb2312_chinese_ci 否 主唱 
Ci Varchar(50) gb2312_chinese_ci 否 歌词 作者 
qu varchar(50) gb2312_chinese_ci 否 歌曲 作者 
actortype varchar(50) gb2312_chinese_ci 否 歌手 类 型 
Style varchar(50) gb2312_chinese_ci 否 音频 类 别 
publisher varchar(100) gb2312_chinese_ci 否 发 行商 
froms varchar(100) ”gb2312_chinese_ci 否 发 行 地 区 
type varchar(50) gb2312_chinese_ci 否 音频 类 型 
sizes varchar(50) gb2312_chinese_ci 否 音频 大 小 
languages varchar(20) gb2312_chinese_ci 否 音频 语言 
publishTime = date 否 发 行 时 间 
remark varchar(1000) gb2312_chinese_ci 否 备注 
property varchar(20) gb2312_chinese_ci 否 音频 属性 
address varchar(200) gb2312_chinese_ci 否 音频 地 址 
userName 。 varchar(50) gb2312_chinese_ci 否 发 布 人 姓名 
issueDate 。 datetime 否 发 布 时 间 
downTime int(4) 否 下 载 次 数 
lastTime datetime 最 后 下 载 时 间 
whether varchar(50) gb2312_chinese_ci et 是 否 为 新 品 


图 10.20 音频 信息 列表 结构 


7. tb_videolist (音频 目录 列表 ) 
音频 目录 列表 主要 用 于 音频 文件 的 分 类 管理 ， 有 目录 名 称 、 目 录 级 别 等 。tb_videolist 表 的 结构 如 
图 10.21 所 示 。 


胃 服务 器 : localhost 辣 数据 库 : db_online ， 国 表 :tb_videolist 
字段 类 型 整理 属性 Null 默认 说 明 

id int(4) 否 自动 编号 
grade varchar(50) gb2312_chinese_ci 否 目录 等 级 
name Yarchar(50) gb2312_chinese_ci 否 目录 名 称 
father varchar(50) gb2312_chinese_ci 否 父 全 目录 
UserName varchar(50) gb2312_chinese_ci 否 创建 人 姓名 
issueDate datetime 否 也 障 时 间 


10.21 音频 目录 列表 结构 
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10.5 ”前 人 台 首 页 设计 


10.5.1 前 台 首 页 概述 


online 影视 365 网 的 前 台 首页 的 功能 模块 主要 包括 以 下 3 部 分 : 

回 ”网 站 首部 导航 栏 : 主要 有 影视 专区 、 音 乐 专区 、 上 传 专区 和 点 歌 专区 。 

回 ”网 站 左 侧 导航 栏 : 包括 会 员 登 录 模 块 、 搜 索 模块 和 影视 排行 模块 。 

回 ”网 站 主 显示 区 : 包括 最 新 上 传 模块 、 视 频 模块 和 音频 模块 

下 面 看 一 下 本 案例 中 提供 的 前 台 首页 ， 该 首页 在 本 书 光盘 中 的 路 径 为 \TM\10\online\index.php， 如 
图 10.22 所 示 。 


ones sss 


"村 


We BY . 
NUINE 影 视 365, (和 和 您 共享 经 典 


[忘记 密码 ] 

CQ 站 内 搜索 
Ee 心 x 吃 不 了 # 豆 认 
信息 类 别 : [未 西 印 称 可 关 型 ;香港 剧 集 


主演 : 。” 某 某 某 
导演 : 。 某 某 某 
制 片 : 。 某 某 某 


全 | 和] 大 这 [aas】 女人 不 
| 集 大 话 * 游 BAB】 女 人 回 ## 不 是 * 
- 呈 音 乐 下 载 排行 [| 【BAB】 男人 更 t+ 不 是 + 


天 * 口 
1 文 ea 不 是 0 【看 港剧 人 入】 。 心 + 吃 不 了 4 豆腐 【hap] 要 + 一 万 * 


【B&B 矿泉 水 ** 


图 10.22 online 影视 365 前 台 首页 
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10.5.2 前台 首页 技术 分 析 


在 本 章 的 数据 库 分 析 中 已 经 提 到 ， 本 系统 所 使 用 的 连接 数据 库 的 方式 为 ADODB 连接 。 这 里 ， 先 
来 初步 了 解 一 下 ADODB 如 何 连接 MySQL。 

下 面 以 本 系统 使 用 的 数据 库 和 数据 表 为 例 ， 来 介绍 一 下 使 用 ADODB 的 基本 操作 步骤 。 

(1) 载 入 (include) adodb.in.php 文件 。 


include "../ado/adodb.inc.php"; 
(2) 建立 数据 库 类 型 连接 。 
$conn = &ADONewConnection("mysq"); &é or S$conn=&NewADOConnection("mysql"); 
(3) 连接 要 使 用 的 数据 库 。 
$conn->PConnect("db_online"); or $conn->Connect("db_online"): 
(4) 执行 SQL 语句 。 
$recordset = $conn->Execute("select * from tb_audio"); 
(5) 判断 结果 ， 并 对 结果 处 理 。 


if($recordset) // 判 断 execute() 函 数 执行 中 是 否 有 错误 


while(!$recordset->EOF)! // 如 果 没 有 错误 ， 则 配合 wihle 语 句 循 环 输出 结果 
echo $recordset->fields[0]."<br>"; 


S$recordset->movenext(); 1/ 指针 下 移 
} 
} 


(6) 关闭 连接 。 


S$recordset->close(); 
S$conn->close(); 


如 果 是 对 微软 的 ado 有 所 了 解 的 用 户 ， 会 对 上 述 步骤 有 一 种 亲切 感 。 无 论 从 字段 名 称 ， 还 是 从 功 
能 上 ， 两 者 都 非常 相似 ， 所 以 上 手 会 很 轻松 。 没 有 接触 过 aod 的 用 户 也 不 用 心急 ， 用 ADODB 操作 数 
据 库 主 要 就 是 这 6 个 步骤 ， 只 要 记 住 这 个 顺序 ， 做 几 遍 练习 后 ， 也 会 运用 自如 。 

在 本 章 的 最 后 ， 还 有 对 ADODB 类 库 进行 较 详 细 的 讲解 ， 参 见 10.14 节 。 


10.5.3 ”前台 首页 的 实现 过 程 


国 前 台 首页 使 用 的 数据 表 : tb_account、tb_audio、tb_video 
在 首页 中 ， 使 用 到 了 3 个 include 语句 ， 将 导航 栏 、 登 录 框 、 搜 索 框 、 浏 览 区 等 主要 的 模块 加 载 进 
来 。 限 于 篇 幅 ， 这 些 页 面 的 代码 不 做 讲解 了 ， 请 自行 到 光盘 中 查找 。 前 台 首 页 的 实现 代码 如 下 : 
例 程 01 ”代码 位 置 ， 光盘 \TM\10\online\index.php 
<?php 
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session_start(); /开启 session 支 持 
7> 
<script src="js/chkjs" language="javascript"></script> /引入 js 脚本 文件 
<link rel="stylesheet" href="css/style.css" /> // 引 入 css 样 式 文件 
<?php 

include "top.php"; // 首 部 导航 及 LOGO 
> 


<table border="0" cellpadding="0" cellspacing="0"> 
<tr><td width="265" align="center" valign="top"> 
<?php 
include "left.php"; /登录 、 搜 索 框 
> 
</td><td width="605" align="center" valign="top"> 
<2php 
include "main.php"; // 主 浏览 区 
> 
</td></tr></table> 


10.6 ”详细 信息 查看 模块 


10.6.1 信息 查看 模块 概述 


详细 信息 查看 模块 主要 包括 视频 详细 信息 查看 和 音频 详细 信息 查看 两 个 部 分 。 查 看 信息 功能 没有 
权限 限制 ， 无 论 是 游客 还 是 会 员 都 可 以 进行 查看 。 但 查看 页 面 中 的 下 载 和 在 线 视听 按钮 则 是 只 有 会 员 
才 可 以 看 到 的 操作 ， 游 客 只 能 看 到 “返回 ”按钮 ， 用 来 关闭 查看 页 面 的 。 下 面 给 出 信息 查看 框架 图 ， 


如 图 10.23 所 示 。 


图 10.23 信息 查看 流程 图 


10.6.2 ”信息 查看 模块 技术 分 析 


在 这 个 模块 中 ， 所 要 解决 的 技术 难点 就 是 : 系统 需要 根据 不 同 的 浏览 用 户 ， 显 示 不 同 的 操作 权限 。 


“5. 


PHP 项 目 开发 全 程 实录 


这 里 是 使 用 让 语句 ， 配 合 session 来 实现 其 功能 的 。 首 先 通过 检测 $_SESSION[name] 是 否 存在 ， 来 判断 
用 户 是 否 登 录 ， 如 果 没 有 登录 ， 则 跳 过 “在 线 视 听 ” 和 “下 载 ”， 只 显示 “返回 ”按钮 ， 如 果 用 户 为 
登录 会 员 ， 则 显示 “在 线 播放 ”按钮 ， 接 着 判断 S_SESSION[grade] 是 否 为 “高 级 会 员 ”， 如 果 登 录 会 
员 为 普通 会 员 ， 则 “下 载 ”按钮 为 灰色 失效 状态 ， 如 果 登 录 会 员 为 “高 级 会 员 ”， 则 同时 显示 3 个 按 
钮 的 全 部 功能 。 该 功能 的 关键 代码 如 下 : 
例 程 02 ”代码 位 置 ， 光盘 \TM\10\online\intro.php 
<?php 
局” 如 果 用 户 是 登录 会 员 */ 
if($_SESSION[name]—>"" ){ 
?> 
<!-- 显示 “播放 ”按钮 --> 
0 <input name="Submit" type="submit" value=” 播 放 " 
onclick="javascript:Wopen=open('operation.php?action=see&id=<?php echo 
Srst->fields[16]; ?>",","'height=700,width=665,scrollbars=n0');"> 
<?php 
履 ” 如 果 是 登录 会 员 */ 
}ift$_SESSION[name]—>"){ 
> 
上 # ”如果 是 高 级 会 员 ， 则 “下 载 ” 按 钮 为 激活 状态 ， 否 则 为 灰色 */ 
@ <input name="Submit” type="button”<?php if ($_SESSION[grade]<>" 高 级 会 员 "){ echo "disabled";}?> 
value=” 下 载 "onclick="javascript:Wopen=location=download.php?action=audio&id=<?php echo 
S$rst->fields[16]; ?>";"> 
<?php 
上 
入 


让 显示 “返回 ”按钮 */ 
© ”<input name="Submit2" type="button" value="” 返 回 "class="submit" 
‘onClick="javascript:top.window.closeO|;"></td> 


Ah 代码 贴 十 
@ open() 方 法 可 以 打开 一 个 无 边框 的 子 窗口 。 关 于 open 方法 的 介绍 ， 可 以 参考 10.13 章 。 
@ disabled: 译 为 无 效 的 、 不 起 作用 的 ， 这 里 是 button 按钮 的 属性 ， 即 不 可 点 击 状态 。 
目 top.window.close(): 关闭 弹出 窗口 。 


10.6.3 ”信息 查看 的 实现 过 程 


国 ”消息 管理 模块 使 用 的 数据 表 : tb_audio、tb_video 
用 户 可 以 在 信息 展示 页 面 单 击 诅 图 标 进入 详细 信息 展示 页 面 。 详细 信息 展示 页 面 主要 是 根据 传递 
的 参数 进行 数据 库 检 索 ， 并 将 结果 集 输出 到 浏览 器 中 。 查 看 页 面 的 运行 结果 如 图 10.24 所 示 。 
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视频 数据 详细 内 容 


: 食 #* 神 
: 2986613 
:无 限制 级 


发 行 时 间 : 2007-12-26 
新 品 : 1 
remark 2 


回 


| | 
图 10.24 详细 信息 页 面 的 运行 结果 
在 详细 信息 展示 页 面 (intro.php) 中 ， 通 过 id 值 从 数据 表 中 提取 所 要 显示 的 信息 输出 到 页 面 ， 当 
文件 信息 输出 完毕 后 ， 通 过 session 值 来 判断 访问 者 是 游客 还 是 会 员 ， 如 果 是 游客 ， 则 只 显示 “返回 ” 
按钮 ， 如 果 是 会 员 ， 还 要 显示 “在 线 试听 ”按钮 和 “下 载 ” 按 钮 。 程 序 的 关键 代码 如 下 : 
例 程 03 ”代码 位 置 ， 光盘 \TM\10\online\intro.php 


<2php 
session_start(); // 开 启 session 支 持 
include "conn/conn.php"; // 载 入 数据 库 连接 文件 
> 
<link rel="stylesheet" href="css/style.css"> 1/ 引入 css 样式 文件 


<!-- 显示 数据 详细 信息 -全 


$sql="select * from tb_audio where id=".$_GET[id]; // 根 据 id 生 成 查询 语句 
SIrst = $conn->execute($sql); // 执 行 SQL 语 句 ， 返 回 结果 集 
让 ”如 果 结 果 集 不 为 空 ， 则 输出 信息 */ 
if(!$rst->EOF){ 
和 


<?php 
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<table width="400" border="0" align="center" cellpadding="0" cellspacing="0"> 
<tr> 
<td height="15" colspan="2">&nbsp:<ltd> 
</t> 
<!-- 输出 视频 名 称 --> 
<tr> 
<td width="131" height="20" align="right" valign="middle"> 名 称 : </td> 
<td width="269" height="20"><?php echo Srst->fields[1]:; ?></td> 
</t> 
<!-- 输出 文件 大 小 -> 
<tr> 
<td height="20" align="right" valign="middle"> 大 小 : </td> 
<td height="20"><?php echo Srst->fields[3]; ?></td> 
</t> 


<tr> 


<td height="30" colspan="2" align="center" valign="middle"> 
上 # ”根据 不 同 用 户 ， 显 示 不 同 权限 */ 


10.7 ”点 歌 模块 设计 


10.7.1 点 歌 模块 概述 


用 户 通过 主导 航 条 进入 点 歌 专区 。 在 点 歌 专区 ， 可 以 对 专区 内 的 音乐 进行 试听 、 浏 览 音 频 信 息 的 
详细 内 容 和 打开 点 歌 页 面 进行 点 歌 ， 进 行 点 歌 的 前 提 条 件 是 用 户 必 须 登 录 。 点 歌 模块 的 用 例 图 如 
图 10.25 所 示 。 


在 线 试听 


图 10.25 ”点 歌 模块 的 用 例 图 


10.7.2 ”点 歌 模块 技术 分 析 


本 系统 的 在 线 点 歌 模块 实现 了 会 员 间 发 送 祝 福 与 点 歌 的 功能 , 收 到 祝福 的 会 员 可 以 实现 在 线 听 歌 。 
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本 节 和 下 一 节 的 “在 线 视听 模块 ” 中， 将 逐一 介绍 实现 在 线 视 听 的 两 种 方法 。 本 节 先 来 介绍 html 标签 
中 的 播放 多 媒体 标签 <embed>。 
1. 基本 语法 
<embed src=url> 
url 为 音频 或 视频 文件 的 其 路 径 ， 可 以 是 相对 路 径 ， 也 可 以 是 绝对 路 径 。 


<embed> 可 以 用 来 播放 各 种 多 媒体 文件 ， 格 式 可 以 是 midi、wav、mp3 等 ， 当 下 主流 的 浏览 器 都 
支持 该 标签 。 


2. 属性 设置 


表 10.1 <embed> 常 用 属性 及 说 明 
属 性 名 说 了 明 举例 
该 属性 规定 音频 或 视频 文件 是 否 在 下 载 完 之 后 就 自动 播放 Re 
true: 音乐 下 载 完成 后 自动 播放 。false 下 载 完成 后 不 播放 。 | ep” alostar te> 
该 属性 规定 音频 或 视频 文件 是 否 循环 及 循环 次 数 
loop 属性 值 为 tue 时 ， 音 频 或 视频 文件 循环 ， 属 性 值 为 false 时 ， <embed src="1.mp3" loop=true> 
音频 或 视频 文件 不 循环 。 如 果 为 正 整数 ， 则 为 循环 次 数 
该 属性 规定 控制 面板 是 否 显示 ， 默 认 值 为 no 


autostart 


hidden ture， 隐藏 面板 ，no， 显 示 面 板 <embed src="1.mp3" hidden="yes"> 
ee 该 属性 规定 音频 或 视频 文件 开始 播放 的 时 间 。 未 定义 则 从 文 | <embed src="1.mp3" 

件 开头 播放 starttime="00:10"> 

该 属性 规定 音频 或 视频 文件 的 音量 大 小 。 未 定义 则 使 用 系统 区 i 
volume 本 身 的 设 定 <embed src="1.mp3" volume="10"> 
width 该 属性 规定 了 控制 面板 的 宽度 <embed sre="1.mp3" width="100"> 
height 该 属性 规定 了 控制 面板 的 高 度 <embed src="1.mp3" height="200"> 
title 该 属性 规定 音频 或 视频 文件 的 说 明文 字 et 


除了 这 些 属性 外 ，<embed> 标 签 还 可 以 面板 的 外 观 进行 设置 ， 对 面板 的 背景 色 和 前 景色 进行 设置 ， 
感 兴趣 的 读者 可 以 查找 相关 的 资料 。 


10.7.3 ”点 歌 模块 的 实现 过 程 
国 ”消息 管理 模块 使 用 的 数据 表 : tb_register、tb_video 


单 击 “ 点 歌 专区 ” 超 链接 ， 首 先进 入 到 点 歌 专区 页 面 ， 页 面 中 的 音乐 试听 和 信息 查看 在 其 他 模块 
中 都 有 介绍 ， 这 里 主要 看 一 下 点 歌 功 能 。 单 击 妖 小 图 标 ， 将 进入 到 点 歌 信息 页 面 ， 点 歌 页 面 的 运行 结 


果 如 图 10.26 所 示 。 
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点 播 
用 户 名 : Tsoft 【aa5] 矿泉 水 ty 某 某 某 司 [3 Een 
等 级 : 首 通 会 员 Can] 要 :一 万 * 某 某 蘑 加 加 En 
上 传 数量 : 【ap] 男人 器 t+ 不 是 + 某 某 某 Eu [| 屿 
【aas] 女人 器 不 是 * 某 某 某 Ey [3 岛 
会 员 帝 和 料 候 必 | 四 可 采 a i i 图 多 


点 歌 记 录 详 单 
接收 和 人， [soft 
祝福 语 : ui 祝 你 节日 快乐 


[点 或 | 返 
图 10.26 点 歌 模块 的 运行 结果 


在 点 歌 信息 页 面 ,需要 用 户 添加 祝福 语 和 接收 和 名称。 点 歌 页 面 涉及 到 的 HTML 表单 元 素 如 表 10.2 
所 示 。 


区 国 


表 10.2 点 歌 页 面 中 的 主要 表单 元 素 


名 称 类 型 重要 属性 

list | form action="Register.asp?action=add" 表单 
toname | text id="toname" size="30" 接收 人 名 称 
remark, textarea cols="40" rows="5" id="remark" 


id Hidden value="<?php echo $_GET[id] 2>" 所 点 歌曲 的 地 址 
submit button onClick="register()" “点 歌 ” 按 钮 
submit2 button onClick="j “返回 ”按钮 
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在 点 歌 页 面 ， 将 前 页 传 过 来 的 歌曲 id、 接收 人 、 祝 福 语 等 信息 组 成 insert 语句 存储 到 数据 库 中 ,不 
管 保存 成 功 与 否 ， 都 将 关闭 当前 子 窗口 ， 回 到 父 窗口 中 进行 操作 。 程 序 代码 如 下 : 


例 程 04 ”代码 位 置 ， 光盘 \TM\10\online\give.php 


<?php 
session_start(); /开启 session 支 持 
if($_POST[toname] > "){ /如 果 接 收 人 不 为 空 
$id=$_POST[id]; /歌曲 id 
$toname=$_ POST[toname]; /接收 人 姓名 
$from=$_ SESSION[name]; /发 送 人 姓名 
S$remark=$_POST[remark]; /备注 信息 


<!-- ”生成 insert 语 句 --> 
$sql="insert into tb register Values(",".$id.",".$from.",".$toname.",".$remark.",".date("Y-m-d H:i:s").")"; 
S$rst = $conn->execute( $sql); // 执 行 SQL 语 句 
> 
<script language="javascript"> 
<?php 
if(!($rst == false)){ 
> 
alert(" 点 歌 信息 保存 成 功 "); 
<?php 
JYelsef 
> 
alert(" 点 歌 失败 "); 
<?php 
} 
> 
top.window..close(); 
</script> 
<?php 


} 
> 


10.8 ”在线 视听 模块 设计 


10.8.1 在 线 视听 模块 概述 


在 线 视听 主要 包括 视频 数据 在 线 观 看 和 音频 数据 在 线 收 听 两 个 部 分 。 在 不 同 的 页 面 都 可 以 直接 进 
入 视听 页 面 ， 包 括 首 页 、 搜 索 结 果 页 、 内 容 介绍 页 和 列表 页 。 但 必须 是 登录 会 员 才 可 以 ， 游 客 是 没有 
权限 的 。 下 面 给 出 在 线 视听 流程 图 如 图 10.27 所 示 。 
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影视 展示 页 


[在 线 观 看 ”| 在 线 试听 
图 10.27 在 线 试听 流程 图 


10.8.2 ”在 线 视听 模块 技术 分 析 


在 10.7.2 中 学 习 了 如 何 使 用 <embed> 多 媒体 标签 来 播放 影音 文件 .本 节 来 学 习 另 一 种 方法 :<object> 

使 用 <object> 标 签 来 定义 一 个 嵌入 的 对 象 。 该 对 象 向 HTML 页 面 添加 多 媒体 。 此 元 素 运行 插入 
到 html 页 面 中 的 对 象 的 数据 和 参数 ， 以 及 可 用 来 显示 和 操作 数据 的 代码 。<object> 标 签 的 基本 格 
式 为 : 

<object classid="clsid:22D6F312-BOF6-11D0-94AB-0080C74C7E95" height="68" id="MediaPlayerl" width="460"> 


<param name="ShowStatusBar" value="-1"> 
<param name="Filename" value="<?php echo $ GET[id]?>"> 


</object> 
classid: 定义 嵌入 Windows Registry 中 或 某 个 URL 中 的 类 的 ID 值 , 此 属性 可 用 来 制定 浏览 器 
中 包含 的 对 象 的 位 置 。 


param: 可 定义 用 于 对 象 的 run-time 设置 。 

<object> 是 微软 专门 为 正 浏览 器 打造 的 、 可 以 扩展 外 部 应 用 程序 及 插件 的 对 象 标签 , 它 和 <embed> 
的 不 同 之 处 在 于 : <object> 只 支持 以 IE 技术 为 核心 的 浏览 器 系列 ， 对 其 他 的 浏览 则 无 效 。 而 且 如 果 要 
使 用 <object> 来 播放 多 媒体 ， 那 么 需要 安装 相应 的 播放 插件 ， 如 realplay、quicktime 等 。 


10.8.3 ”在线 视听 模块 的 实现 过 程 
国 ”在 线 视听 模块 使 用 的 数据 表 : tb_audio、tb_video 


会 员 可 以 在 首页 、 信 息 展 示 页 面 或 者 详细 信息 展示 页 面 单 击 “ 观 看 ”或 “试听 ”按钮 进行 在 线 视 
听 操 作 。 页 面 运行 结果 如 图 10.28 所 示 。 


Se 
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“omnes 视 365 


图 10.28 在线 视听 模块 的 运行 结果 
以 视频 详细 信息 展示 页 面 为 例 , 用 户 可 以 单 击 唱 | 图标， 打开 视频 播放 页 面 (see.php) 进行 在 线 观看 。 
视频 播放 页 面 主要 是 根据 传递 的 参数 进行 数据 库 检索 , 并 将 对 应 数据 的 硬盘 存储 地 址 作为 多 媒体 文件 的 引 
用 地 址 ， 当 页 面 加 载 完毕 后 ， 视 频数 据 将 自动 播放 ， 实 现在 线 观看 功能 。 在 线 播放 页 面 的 主要 代码 如 下 : 
例 程 05 ”代码 位 置 ， 光盘 \TM\10\online\see.php 


<?php 
session_start(); 1/ 开启 session 支 持 
> 
<body> 
<!-- ”使 用 object 对 象 播放 视频 /音频 文件 -> 
<object classid="clsid:22D6F312-BOF6-11D0-94AB-0080C74C7E95" width="665" height="500" id="MediaPlayerl" > 
<L-- 设置 自动 播放 -> 
<param name="AutoStart" value="-1"> 
<L- 设置 状态 栏 -> 
<param name="ShowStatusBar" value="-1"> 
<L- 播放 文件 路 径 -> 
<param name="Filename" value="upfiles/audio/<?php echo $ GET[id]; ?>"> 
</object> 


</body> 
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10.9 后 人 台 首 页 设计 


10.9.1 后 台 首页 概述 


根据 用 户 对 各 个 功能 模块 的 使 用 频率 和 重要 程度 ,本 系统 的 首页 面 中 要 显示 的 模块 主要 有 两 部 分 : 

(1) nie a 

回 管理 模块 : 主要 包括 视频 目录 管理 和 音频 目录 管理 两 个 部 分 。 

回 0 理 模 块 : he 1 频数 据 管理 两 个 部 分 。 

会 员 管理 模块 : 包括 会 员 等 级 管理 、 会 员 信息 冻结 、 会 员 信息 删除 3 个 部 分 。 

上 传 信息 管理 模块 : 主要 用 于 浏览 和 查询 用 户 上 传 操作 的 详细 内 容 

管理 员 设 置 模块 : 主要 包括 管理 员 信息 添加 、 删 除 、 冻 结 3 个 部 分 。 

(2) 网 站 主 显示 区 : 显示 各 个 模块 的 操作 及 结果 。 

下 面 看 一 下 本 案例 中 提供 的 后 台 首 页 , 该 首页 在 本 书 光盘 中 的 路 径 为 \TM\10\online\admin\index.php， 
如 图 10.29 所 示 。 


曾 视频 目录 管理 会 员 数 据 管理 


-再 二 人 
ET mn 等 级 用 户 各 真实 姓名 操作 
St 1 。 普通 会 员 Tsoft sn 洒 缚 ] gs 
玉音 乐 数据 世 理 11 。 普通 会 员 1y E33 
曾 会 员 等 级 设置 12 ”普通 会 员 1 删除 
司 会 员 涛 据 芝 再 10 。 苦 通 会 员 sen 开除 
Et 和 0 
13 普通 会 员 111 [| am 
部 管理 设置 144。 省 通 会 员 3333 E33 


图 10.29 ”online 影视 365 后 台 首页 
10.9.2 ”后台 首页 技术 分 析 


本 系统 的 后 台 首 页 采用 的 布局 结构 为 二 分 栏 布 局 。 左 侧 导 航 栏 清楚 、 明 白地 显示 了 后 台 管 理 员 所 
能 使 用 到 的 功能 。 当 单 击 任意 功能 按钮 时 ， 在 主 显示 区 显示 对 应 的 操作 界面 ， 和 该 功能 模块 下 的 子 功 
能 。 页 面 简 练 、 结 构 清晰 、 浏 览 方 便 ， 二 分 栏 的 主要 特点 被 表现 的 淋漓 尽 致 。 关 于 二 分 栏 的 详细 介绍 ， 
请 看 3.6.3 节 和 4.7.1 节 


Se 
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10.9.3 后 台 首页 的 实现 过 程 


国 ”后 台 首 页 使 用 的 数据 表 : tb_manager 


下 面 来 看 一 下 后 台 首 页 的 实现 过 程 。 在 首页 代码 中 ， 对 每 项 功能 权限 的 判断 都 是 在 left.php 中 完成 


4 ， 只 要 在 左 侧 导 航 栏 的 位 置 载 入 left.php 即 可 。 在 主 显示 区 ， 根 据 参数 返回 


能 界面 。 程 序 的 关键 代码 如 下 : 


例 程 06 ”代码 位 置 : 光盘 \TM\10\online\admin\main.php 


<?php 
session_start(); 
include "inc/chec.php"; 
include "conn/conn.php"; 
> 
<link href="css/style.css" rel="stylesheet"/> 


<script sre="js/admin js.js" language="javascript"></script> 


<center> 


<?php 

上 #” 载 入 网 站 左 侧 导 航 栏 */ 
include "left.php"; 

> 


<div style="height:35px;">&nbsp;</div> 
<?php 
人 # ”根据 不 同 的 参数 ， 显 示 不 同 的 功能 界面 */ 
if(isset($ GET[action]))f 
switch ($ GET[action]){ 
ase "audioList": 
include "a list.php"; 
break; 
case "videoList": 
include "v_list.php"; 
break; 
case "audio": 
include "audio.php"; 
break; 
case "video": 
include "video.php"; 
break; 
case "grade": 
include "grade.php"; 
break; 
case "member"; 
include "member.php"; 
break; 
case "log"; 
include "log.php"; 
break; 


case "manager"; 


// 开 启 session 支 持 
// 载 入 权限 检查 文件 
// 载 入 数据 库 链接 文件 


/1/ 引 入 css 样 式 文件 
// 引 入 js 脚本 文件 


// 视 频 目录 名 称 添加 


// 音 频 目 录 添加 


// 视 频数 据 添加 


// 音 频数 据 添 加 


// 会 员 等 级 设置 


// 会 员 数 据 设置 


/上 传 日 志 管理 


/管理 员 设置 


的 不 同 值 ， 显 示 不 同 的 功 


A 


PHP 项 目 开发 全 程 实录 
include "manager.php"; 
break; 
有 


> </td></tr> 
<tr><td height="15" bgcolor="#f0f0f0">&nbsp;</td></tr> 
</table> 
</td></tr> 
</table> 
</center> 


10.10 ”目录 管理 模块 设计 


10.10.1 目录 管理 模块 概述 


目录 管理 模块 主要 包括 视频 目录 管理 和 音频 目录 管理 两 个 部 分 。 管 理 员 可 以 通过 后 台 管 理 导航 进 
入 对 应 的 目录 管理 页 面 。 
如 果 管 理 员 进 入 了 视频 目录 管理 页 面 (audiolisphp) ， 那 么 在 该 页 面 内 可 以 打开 目录 添加 页 面 进 
行 目录 添加 操作 ， 也 可 以 删除 相应 的 目录 。 鉴 于 目录 信息 比较 简短 ， 本 例 中 没有 提供 目录 修改 的 功能 。 
目录 管理 模块 的 用 例 图 如 图 10.30 所 示 。 


二 CE <— 一 一 >( 添加 视频 目录 ) < 一 一 
添加 音频 目录 Cosea) 
CI i 管理 员 


图 10.30 视频 目录 管理 用 例 图 


[ED 说明: 由 于 视频 目录 管理 和 音频 目录 管理 实现 的 方法 基本 类 似 ， 因 此 ， 本 章 重点 讲解 视频 目录 管 
理 模块 实现 的 方法 ， 关 于 音频 目录 管理 模块 的 实现 方法 请 参见 本 书 附 赠 源码 光盘 。 


10.10.2 ”目录 管理 模块 技术 分 析 


在 本 系统 中 ， 有 个 功能 经 常 要 被 用 到 : 就 是 在 添加 目录 、 歌 曲 时 ， 经 常会 碰 到 重 名 的 问题 。 对 于 
这 个 问题 ， 可 以 写 一 个 自 定义 函数 ， 并 将 它 放 到 单独 的 一 个 文件 中 ， 方 便 其 他 页 面 调 用 ， 如 本 系统 中 
的 /inc/func.php， 就 是 专门 用 来 存储 自 定义 函数 的 文件 。 

下 面 来 看 一 下 自 定义 函数 is_chk0。 

例 程 07 ”代码 位 置 ， 光盘 \TM\10\online\admin\inc\func.php 


// 判 断 目录 名 是 否 重复 
//Sf_fields: 字段 名 
/Stablename: 数据 表 名 
//Sf_str: 要 查找 的 字段 


function is_chk($f fields,$tablename,$f str){ 
\ .486 。 
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$conn = &ADONewConnection(mysql); /建立 mysql 连 接 
$conn->PConnect("localhost","root","root","db_online"); // 连 接 "db_online" 数 据 库 
S$is_chk = true; // 声 明 一 个 boolean 型 变量 
S$is_sqlstr = "select $f fields from $tablename"; // 查 找 字段 


S$is_rst= $conn->execute($is_sqlstr); 


while(!Sis_rst->EOF){ 
/本 于 于 束 训 于 束 | 


} 


if($f str 一 $is_rst->fields[O]){ 
证 ”如 果 字 段 在 数据 库 中 找到 ， 说 明 重 名 了 ，is_chk 设 置 成 false */ 


Sis chk = false; 
break; 


} 


Sis_rst->MoveNext(); 


Teturn $is_chk; 


L 


10.10.3 ”目录 管理 的 实现 过 程 


// 循 环 输出 记录 集 


一 一 对 比 字 段 中 的 值 ”****#**##*# 相 二/ 


// 将 指针 指向 下 一 条 记录 
// 返 回 变 量 $is_chk 


国 目录 管理 使 用 的 数据 表 : tb_audiolist、tb_videolist 
单 击 左 侧 导 航 栏 中 的 “视频 目录 管理 ” 超 链 接 ， 可 以 打开 视频 目录 管理 页 面 ， 在 管理 页 面 中 ， 有 


一 个 “目录 添加 ” 超 链接 、 所 有 的 一 、 


果 如 图 10.31 所 示 。 


-级 目录 信息 和 对 应 的 “删除 ”按钮 。 视 频 管理 页 面 的 运行 结 


男 | 四 | 四 | 男 | 下 | 加 | 印 | 印 


视频 目录 管理 
音乐 目录 管理 
视频 数据 管理 
音乐 数据 闪 理 
会 员 等 级 设置 
会 员 数据 管理 
上 传 日 志 管理 
管理 员 设置 


图 1031 


视频 目录 管理 

目录 添加 
I 和 名 称 从 地名 称 操作 
a 2 者 洪 出入 电视 各 辽 | 
20 2 大 陆 剧 集 电视 到 除 
15 1 电影 天 除 
16 1 电视 贡 除 
1 2 喜 出 电影 开除 
8 2 更 岂 电影 各 用 
1 2 利和 电影 基 除 
2 2 其 地 剧 入 电视 删除 
2 2 欧美 剧 集 电视 角 除 
2 2 日 站 剧 扩 电视 到 除 

视频 目录 管理 的 运行 结果 


地 
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视频 目录 管理 页 面 的 代码 很 简单 : 使 用 while 循环 将 数据 库 中 的 记录 全 部 显示 出 来 , 并 在 每 输出 一 
条 记录 后 ， 添 加 一 个 “删除 ”操作 。 目 录 管 理 页 面 的 实现 代码 如 下 : 
例 程 08 ”代码 位 置 ， 光盘 \TM\10\online\admin\a_list.php 


<?php 
session_start(); /开启 session 支 持 
include "conn/conn.php"; // 载 入 数据 库 链接 文件 
include "inc/chec.php"; // 载 入 权限 检查 文件 


上 # ”输出 视频 目录 数据 表 中 的 全 部 数据 */ 
$1 sqlstr = "select* from tb audiolist"; 
$l_rst = $conn->execute($]_sqlstr); 


<tr> 
人 # 目录 添加 */ 
<td height="10" colspan="5" align="right" valign="middle"><a href—="#" 
onclick="javacript:Wopen=open("operation.php?action=audiolist',' 添 加 目录 ','height=500,width=665,serollbars=n0');"> 
目录 添加 </a></td> 
</tr> 
<!-- 显示 目录 相关 信息 的 字段 名 --> 
<tr> 
<td height="30" align="center" valign="middle">ID</td> 
<td height="30" align="center" valign="middle"> 等 级 </td> 
<td height="30" align="center" valign="middle"> 名 称 </td> 
<td height="30" align="center" valign="middle"> 父 级 名 称 </td> 
<td height="30" align="center" valign="middle"> 操 作 </td> 


</tr> 
<?php 
while(!$l rst->EOF)! 
> 
<tr> 
<!-- 输出 目录 id -> 


<td height="18" align="center" valign="middle"><?php echo $1] rst->fields[0]; ?></td> 
<!-- 输出 目录 等 级 --> 
<td height="18" align="center" valign="middle"><?php echo $l]_rst->fields[1]; ?></td> 
<!-- 输出 目录 名 称 -> 
<td height="18" align="center" valign="middle"><?php echo $1 rst->fields[2]; ?></td> 
<!-- 输出 目录 父 级 名 称 -> 
<td height="18" align="center" valign="middle"><?php echo $l] rst->fields[3] ?></td> 
<!-。 输出 “删除 ” 超 链接 -> 
<td height="18" align="center" valign="middle"><a 
href="del_list_chk.php?action=audiolist&id=<?php echo $1_rst->fields[0]; ?>" onclick="retum del_chk();"> 删 除 </a> 

</td> 

<t> 

<2php 
上 # 指针 下 移 一 条 记录 */ 
$1 rst->MoveNext(); 


} 
> 


</table></td> 
</t> 


。488 。 
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</table></td> 
<ltr> 
</table> 


10.10.4 目录 添加 的 实现 过 程 
国 ”目录 添加 使 用 的 数据 表 : tb_audiolist、tb_videolist 


图 10.32 所 示 。 


视频 目录 名 称 深 加 
目录 名 称 :FR 
目录 级 别 :| 二 级 目录 司 
父 级 和 名称: [ 电 彩 司 
区 到 [下 可 
图 10.32 视频 添加 目录 的 运行 结果 
视频 目录 添加 页 面 (audiolist.php ) 中 主要 包含 一 个 添加 目录 表单 , 表 
表 10.3 视频 目录 添加 页 面 涉及 到 的 HTML 表单 元 素 
名 称 | 类 型 重要 属性 


list form method="post" action="audiolist_chk.php" 
name="grade" OnChange="check()" 

grade select <option value="1" selected> 一 级 目录 </option> 
<option value="2"> 二 级 目录 </option> 

<2php 


的 主要 元 素 如 表 10.3 所 示 。 


含义 
视频 目录 添加 表单 


目录 等 级 


$1_sqlstr = "select * from tb_audiolist where grade ="1"; 
$1_rst = $conn->execute($]_sqlstr); 

while(!$l_rst->EOF){ ?> 

<option value="<?php echo $l_rst->fields[2]; ?>"><?php echo 
$1_rst->fields[2]; ?></option> 

<2php Sl_rst->MoveNext(); 
}7> 


father select 


父 级 目录 名 称 


目录 名 称 
“添加 ”按钮 


names text type="text" id="names" 
Submit submit class="submit" value=" 添 ”加 " onclick="return n_chk();" 


class="submit" value=" 返 ” 回 " 


“返回 ”按钮 


学 


Submit2 button 


onClick="javascript:top.window.closeO” 
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当 管 理 员 添加 信息 提交 后 ， 系 统 转 到 处 理 页 中 (audiolist_ chk.php) 进行 添加 操作 。 首 先 判断 输入 
目录 名 称 是 否 与 已 存在 的 名 称 重 复 ， 如 果 重 复 ， 回 到 上 一 步 。 如 果 不 重复 ， 则 向 数据 表 中 添加 新 记录 。 
视频 目录 添加 的 程序 代码 如 下 : 

例 程 09 ”代码 位 置 ， 光盘 \TM\10\online\admin\audiolist_chk.php 


<?php 
session_start(); // 开 启 session 支 持 
include "inc/chec.php"; // 载 入 权限 检查 文件 
include "conn/conn.php"; // 载 入 数据 库 连 接 文 件 
include "inc/func.php"; // 载 入 自 定义 函数 文件 


/* ”使 用 自 定义 函数 is_chk0， 判 断 用 户 名 是 否 重复 */ 

if(lis_chk("name","tb_audiolist",$ POST[names]) 一 false){ 
echo "<script>alert(' 名 称 重 复 ');history.go(-1);</script>"; /如 果 重 复 ， 退 到 上 一 步 操作 
exit(); 


} 
证” 生成 insert 插 入 语句 */ 
$a sqlstr = "insert into tb audiolist (grade,name,father,userName,issueDate) 


values('$ POST[gradel]','$ POST[names],$ POST[father]','$ SESSION[admin]',".date("Y-m-d H:i:s").")"; 


> 


让 ”判断 返回 结果 */ 
if($conn->execute($a_sqlstr) 一 false) 
上 # ”如 果 添 加 失败 ， 返 回 上 一 步 */ 
echo "<script>alert(' 添 加 失败 ');history.go(-1);</script>"; 
else 
证 ”如 果 添 加 成 功 ， 则 刷新 父 窗口 ， 关 闭 子 窗口 */ 
echo "<script>top.opener.location.reload(;alert( 添 加 成 功 ');window .close();</script>"; 


10.10.5 ”目录 删除 的 实现 过 程 


国 


目录 删除 使 用 的 数据 表 : tb_audiolist、tb_videolist 


视频 目录 的 删除 功能 是 根据 传递 的 目录 id 号 将 数据 库 中 对 应 的 记录 找到 , 并 删除 , 程序 代码 如 下 : 
例 程 10 ”代码 位 置 : 光盘 \TM\10\online\admin\del_list_chk.php 


<2php 

session_start(); // 开 启 session 支 持 
include "inc/chec.php"; // 载 入 权限 检查 文件 
include "conn/conn.php"; // 载 入 数据 库 链 接 文 件 
if($_GET[action] 一 "audiolist") // 如 果 action 等 于 audiolist 

S$t_name = "tb_audiolist"; // 要 访问 的 数据 表 就 为 tb_audiolist 
else if$_GET[action] 一 "videolist") // 如 果 action 等 于 videolist 

S$t_name = "tb_videolist"; /那么 数据 库 表 就 为 tb_videolist 
$sqlstr = "delete from ".$t_name." where id =".$_GETT[id]; /根据 id 号 ， 删 除 对 应 记录 


> 


NE 


证 ”如 果 删 除 成 功 ， 则 返回 到 当前 页 ， 否 者 ， 退 到 上 一 步 */ 
if($rst = $conn->execute($sqlstr) 一 false){ 
echo "<script>alert(' 删 除 错误 ! ".$sqlstr.");history.go(-1);</script>"; 
jelse 
echo "<script>alert(' 删 除 成 功 '");location=".$_SERVERI['HTTP_REFERER'].";</script>"; 
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10.11 数据 管理 模块 设计 


10.11.1 数据 管理 模块 概述 


数据 管理 模块 主要 包括 视频 数据 管理 和 音频 数据 管理 两 个 部 分 。 管 理 员 可 以 通过 后 台 管理 导航 进 
入 对 应 的 数据 管理 页 面 ， 如 视频 数据 管理 页 面 (audiophp) 。 在 数据 管理 页 面 ， 用 户 可 以 打开 数据 添 
加 页 面 或 删除 对 应 的 数据 。 数 据 管理 模块 用 例 图 如 图 10.33 所 示 。 


/ED /LED 


音频 目录 管理 员 超级 用 户 视频 目录 管理 员 
~ 添加 音频 文件 Pe 添加 视频 文件 


图 10.33 ”数据 管理 模块 用 例 图 


[EQ 说明: 由 于 视频 数据 管理 和 音频 数据 管理 实现 的 方法 基本 类 似 ， 因 此 ， 本 章 重 点 讲解 视频 数据 管 
理 模块 实现 的 方法 ， 关 于 音频 数据 管理 模块 的 实现 方法 请 参见 本 书 附 赠 源码 光盘 。 


10.11.2 数据 管理 模块 技术 分 析 


在 本 模块 中 ， 主 要 运用 的 就 是 文件 上 传 技术 。 关 于 文件 上 传 方面 的 知识 ， 请 参见 第 8 章 博 客 管理 
系统 中 的 8.7 节 ， 里 面 有 对 预定 义 变量 $_FILES 的 详尽 介绍 ， 和 如 何 判断 图 片 类 型 和 大 小 的 相关 方法 。 
在 这 个 模块 中 ， 略 有 不 同 的 是 使 用 了 一 个 自 定义 函数 来 判断 文件 名 后 级 。 下 面 来 看 看 这 个 函数 的 
实现 过 程 : 
例 程 11 ”代码 位 置 : 光盘 \TM\10\online\admin\inc\func.php 
// 判 断 文件 后 级 
/ftype: 允许 文件 的 后 组 类 型 


//$f_upfiles: 上 传 文件 名 
function f_postfix($f type,$f upfiles){ 


Sis_pass = false; // 设 置 一 个 boolean 型 变量 $is_pass 
0 S$tmp_upfiles = split(™"\.",Sf_upfiles); // 拆 分 上 传 文件 名 ， 存 储 到 变量 Stmp_upfiles 中 
@ Stmp_fix = $tmp_upfiles[count(Stmp_upfiles) - 1]; /取得 上 传 文件 名 后 组 
for($num = 0; $num < count($f type):Snum++H){ /使 用 for 循 环 ， 输 出 允许 使 用 的 后 缀 类 型 
目 if(strtolower(Stmp_tix) 一 $Sf_ type[Snum]) /如 果 上 传 文件 后 缀 包括 在 其 中 ， 说 明 类 型 相符 
S$is_pass =true; /Sis_pass 变 量 赋值 为 tue 


| 
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Tetum $is_pass; /返回 变量 $is_pass 
} 

外 代码 贴 士 

@ split("\.",$f_upfiles): split0 〇 函数 为 字符 分 割 函 数 ， 它 有 两 个 参数 : 分 隔 符 、 要 分 割 字符 囊 。 返 回 结 果 为 分 后 后 的 
字符 囊 数组 ,例如 ，$tmp=split("e","placepublicslice")， 那么 $Stmp 值 就 为 Stmp[0]="plac"、S$tmp[1]="epubli"、$tmp[3]="sli"、 
S$tmp[4]="e". 

四 count($tmp_upfiles): count0 函 数 的 作用 是 取得 数组 个 数 。 

@ strtolower($tmp_tix): strtolower() 函 数 返回 参数 字符 串 的 小 写 格式 ， 如 strtolower("AbC")， 输 出 等 于 abc。 


[0 说 明 : 尽 可 能 地 使 用 PHP 函数 库 的 函数 。 因 为 自己 写 的 函数 ， 无 论 是 从 算法 设计 ， 还 是 从 功能 实现 
上 , 都 无 法 和 PHP 自 带 的 函数 相 比较 .。 不 要 试 着 去 找寻 它们 的 错误 , 这 是 非常 不 明智 的 做 法 。 


10.11.3 数据 添加 的 实现 过 程 


国 ”数据 添加 使 用 的 数据 表 : tb audio、tb_video 
管理 员 可 以 通过 单 击 视频 数据 管理 页 面 的 “数据 添加 ”按钮 打开 数据 添加 页 面 Caudiophp) ， 在 
数据 添加 页 面 填写 了 表单 之 后 ， 将 表单 提交 给 本 页 ， 本 页 会 根据 提交 的 表单 数据 在 数据 库 中 添加 对 应 

的 记录 。 数 据 添 加 页 面 的 运行 结果 如 图 10.34 所 示 。 
cn 
S/o/ 7 dt 


ONLINE 
-六 


发 行 国家 :| 中 国 
发 oq: [005-07-07 证 。 


新 如: 全 是 C 百 * 


夺 雪 开 ， 神 全 得 一 于 下 
简要 介绍 : 
到 


ED (am EE 
图 10.34 ”视频 数据 添加 页 面 的 运行 结果 
在 视频 数据 添加 页 面 中 涉及 到 的 HTML 表单 元 素 如 表 10.4 所 示 。 


RY 


名 称 
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类 型 


表 10.4 ”视频 添加 页 面 涉及 到 的 HTML 表单 元 素 
重要 属性 


List 


form 


name= list” method="post” action= "dataadd_ chk.php” 
enctype= ”multipartform-data” 


表单 


Names 


text 


id= names”size 一 30” 


数据 名 称 


Picture 


text 


id= picture”size= 15” 


图 片 名 称 


Address 


text 


id="address” size="15” 


数据 位 置 


Grade 


select 


<option value= "一 级 ”> 一 级 </option> 
”二 级 ”> 二 级 </option> 
<option value=" 三 级 ”> 三 级 </option> 
<option value= "无 限制 级 "selected= "selected > 无 限制 级 </option> 
<option value= "禁片 "> 禁片 </option> 


<option value= 


数据 等 级 


Publisher 


text 


id= publisher ”size 一 30” 


Actor 
Director 
Maker 


Language 


Style 


Types 


text 
text 
text 


radio 


Select 


Select 


id= "actor size= ”30” 


"director 


EA 
<input type="radio” name="language”value=" 中 文 ”checked> 中 文 


id= ”marker si 


<input type="radio” name="language” value=” 
<input type="radio” name="language” valu 


<input type="radio” name="language” value= "日 语 "> 日 语 


<input type="radio” name="language” value=” 


<input type="radio” name="language” value= "法语 

<td> 

<2php S$a_sqlstr="select * from tb_videoList where grade="2™; 
Sa_rst = $conn->execute($a_sqlstr); 
while(!$a_rst->EOF){ 


<option value="<?php echo 

S$a_rst->fields[2]; ?> ><2?php echo $a_rst->fields[2]; ?></option> 
<2php Sa_rst->movenext(); 

} 
> 
<?php 
$t sql = “select * from tb_audiolist where grade = 1 
S$t_rst= $conn->execute($t_sq]); 
while(!$t_rst->EOF)!{ 
> 
<option value="<?php echo $t_rst>fields[2]; ?>"><?php echo 
S$t_rst->fields[2]; ?></option> 
<?php 
S$t_rst->movenext(); 


} 


> 


发 行商 
主要 演员 
导演 
制 片 人 


语种 


类 别 


类 型 
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续 表 
名 称 | 类 型 重要 属性 含义 

From text | id="from" size="30" 发 行 国家 

_publishtime text | loadCalendar(list.publishtime); 发 行 时 间 
<input name="news" ="radio" value="1" checked> 是 

eh ae a name="news" He value="0"> 否 We 

remark textarea | class="submit" onclick="returmn a_chk():" 简要 介绍 

Submit button | class="submit" onclick="retum a_chk():" “添加 ”按钮 

Submit2 button OnClick="javascript:top.window.closeO"> “返回 ”按钮 


视频 管理 处 理 页 〈dataadd_chk) 主要 分 3 部 分 。 图 片 文件 格式 及 图 片 大 小 判断 、 视 /音频 格式 及 文 
件 大 小 判断 ， 信 息 都 准确 无 误 后 ， 则 向 数据 库 中 添加 新 记录 。 处 理 页 处 理 的 程序 代码 如 下 : 
例 程 12 ”代码 位 置 ， 光盘 \TM\10\online\admin\dataadd_chk.php 


<?php 
session_start(); // 开 启 session 支 持 
include "inc/chec.php"; // 载 入 权限 检查 文件 
include "conn/conn.php"; // 载 入 数据 库 链 接 文 件 
include "inc/func.php"; // 载 入 自 定义 函数 文件 
$p_type = array("jpg","jpeg","bmp","gif"); // 允 许 上 传 的 图 片 文件 格式 
$f type = array("avi","rm","rmvb","wav","mp3","mpg"); // 允 许 上 传 的 视频 、 音 频 格式 
$audio_path = "../upfiles\audio"; // 视 频 上 传 位 置 
$video_path = "../upfiles\\video"; // 音 频 上 传 位 置 
S$picture_path =""; /图片 上传 路 径 
$file_path =""; // 文 件 上 传 路 径 


在 图 片 类 型 判断 中 , 首先 判断 图 片 大 小 是 否 在 允许 范围 之 内 , 接着 使 用 自 定义 函数 f_postfix0 来 判断 
图 片 后 缀 是 否 符合 要 求 , 如 果 没有 问题 ， 则 根据 time() 函 数 ， 生 成 图 片 名 , 并 保存 到 变量 $picture_path 中 。 
例 程 13 ”代码 位 置 ， 光 盘 \TM\10\online\admin\dataadd_chk.php 
上 # 判断 图 片 大 小 ， 是 否 大 于 0k， 小 于 700k */ 


0 if($_FILES[picturel[size] > 0 and $ FILES[picturel[size] < 700000){ 
族 ”如果 图 片 格式 正确 */ 

[2 if(($postf =f_postfix(Sp_type,$_FILES[picturel[name])) != false){ 
让 ”使 用 time0 函 数 生成 文件 名 */ 

© S$picture path = timeQ.".".$postf; 


店 ”如果 action 值 为 4 时 ， 说 明 上 传 为 视频 图 片 */ 
if($ POST[action] == "a" 
证” 如 果 生 成 的 临时 文件 正确 ， 则 使 用 move_uploaded_file( 函数 上 传 */ 
if($ FILES[picturel[tmp name]) 
9 move_uploaded file($ FILES[picturel[tmp_name],Saudio path."\".Spicture_path); 

elsef 
echo "<script>alert(' 上 传 图 片 失败 ! ");history.go(-1);</script>"; 
exit(); 


} 
上 # ”如果 上 传 图 片 为 音频 图 片 */ 


jelse if($_POST[action] = "v"){ 
RS *494* 
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if($_FILES[picture][tmp_name]) 

move_uploaded file($_FILES[picture][tmp_name],$video_path."\\".$picture_path); 
elsef 

echo "<script>alert(' 上 传 图 片 失败 ! ");history.go(-1);</script>"; 

exit(); 


} 
jelsef 
echo "<script>alert(' 上 传 图 片 格式 错误 ! ');history.go(-1);</script>"; 
exit(); 
店 ” 如 果 图 片 大 于 700KB, 说 明 图 片 太 大 ， 超 出 要 求 ， 返 回 上 一 步 */ 
}else if($_FILES[picture][size] > 700000){ 
echo "<script>alert(' 上 传 图 片 大 小 超出 范围 ! ');history.go(-1);</script>"; 
exit(); 
} 
else{ 
S$picture = ""; 


/ 检 来 可 于 来 来 事 素来 来 可 可 来 素来 来 来 可 可 来 刺 事 于 刺 率 可 束 束 束 


Ah) 代码 贴 二 

@ 使 用 预定 义 变量 的 $_FILES[namej[size] 属 性 判断 上 传 文件 的 大 小 。 如 果 文件 大 于 pho.ini 中 设置 的 上 传 文件 的 最 
大 值 ， 那 么 size 将 永远 返回 0， 而 不 是 文件 的 实际 大 小 。 

@ 使 用 自 定义 函数 fpostfix() 判 断 上 传 文件 的 后 组 。 

四 返回 当前 UNIX 的 时 间 蕉 

@ 使 用 move_uploaded_file0 上 传 函 数 要 注意 : 它 的 第 一 个 参数 是 上 传 到 服务 器 中 的 临时 文件 名 ， 而 不 是 文件 本 身 
后 ， 是 用 户 自 定义 的 名 称 。 要 取得 临时 文件 名 用 $_FILES[name][tmp_name] 来 获取 。 

对 上 传 文件 的 判断 和 上 传 图 片 的 流程 基本 相同 ， 也 是 先 判断 文件 大 小 是 否 符合 上 传 文件 的 范围 要 
求 ， 接 着 判断 上 传 文件 后 级 ， 最 后 使 用 time0 函 数 生成 文件 名 ,保存 到 变量 $address_path 中 。 下 面 是 判 
断 视频 文件 的 流程 。 

例 程 14 ”代码 位 置 ， 光盘 \TM\10\online\admin\dataadd_chk.php 

上 # 判断 上 传 文件 类 型 与 大 小 */ 


if($_FILES[address][size] > 0){ /判断 上 传 文件 大 小 
if($_POST[action] 一 "a"){ /判断 是 视频 文件 还 是 音频 文件 
if($_FILES[address][size] < 300000000){ // 判 断 文 件 是否 超 出 限定 大 小 
if(($postf = f_postfix($f type,$_FILES[address][name])) 二 false){ 
Sfile_path = time().".".$postf: // 生 成 新 的 文件 名 
if($_FILES[address][tmp_name]) // 如 果 临 时 文件 正确 


/# ”使 用 move_uploaded_file() 函数 上 传 文件 */ 
move_uploaded file($_FILES[address][tmp_name],$audio_path."\\".$file_path); 
else{ 
echo "<script>alert(" 上 传 文件 错误 ! '):history.go(-1);</script>"; 
exit(); 
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}else{ 
echo "<script>alert(" 上 传 文件 格式 错误 ! ");history.back(-1);</script>"; 
exit(); 

}}else{ 

echo "<script>alert("' 上 传 文件 大 小 错误 ! ");history.go(-1);</script>"; 

exit(); 


直 
店 ”如果 是 音频 文件 */ 
else ift$ POST[action] 一 "v"){ 
上 # 判断 文件 大 小 */ 
if($_FILES[address][size] < 10000000){ 
睛 判断 文件 后 级 */ 
if(($postf = f_postfix($f type,$_FILES[address][name])) != false){ 
$file_path = time().".".$postf; 
让 ”判断 临时 文件 是 否 生 成 */ 
if($_FILES[address][tmp_name]) 
/# 使 用 move_uploaded_file0 函数 上 传 文件 */ 
move_uploaded_file($_FILES[address][tmp_name],$video_path."\".$file_path); 
elsef 
echo "<script>alert(' 上 传 文件 错误 ! ');history.go(-1);</script>"; 
exit();} }else{ 
echo "<script>alert(' 上 传 文件 格式 错误 ! ');history.back(-1);</script>"; 
exit();} }else{ 
echo "<script>alert(' 上 传 文件 大 小 错误 ! ");history.go(-1);</script>"; 
exit();}} 
}else{ 
echo "<script>alert(' 没 有 上 传 文件 或 文件 大 于 300M'):history.go(-1);</script>"; 
exit(); 
} 


如 果 上 传 图 片 和 上 传 的 文件 都 没有 问题 则 对 表单 的 其 他 信息 进行 处 理 。 生 成 insert 插入 语句 ， 添 
加 新 记录 : 
例 程 15 ”代码 位 置 ， 光盘 \TM\10\online\admin\dataadd_chk.php 
族 ”视频 文件 和 音频 文件 相同 的 信息 */ 


$names = $_POST[names]; // 视 频 名 称 
S$grade = $_POST[grade]; // 级 别 
$sizes = $_FILES[address][size]; /1/ 大 小 
S$publisher = $_ POST[publisher]; /发 行商 
$actor = $_POST[actor]; /演员 
$language = $_POST[language]; 语言 
$style = $_POST[style]; /类别 
$types = $_POST[types]; // 类 型 
S$froms = $_POST[from]; // 发 行 国家 
S$publishtime = $_POST[publishtime]; // 首 映 时 间 
$news=$_POST[news]; /是 否 为 新 片 
S$remark = $_ POST[remark]: /备注 

st 六 六 六 六 水 米 率 冰冰 闵 术 六 水 闵 / 


if($_POST[action] 一 "a"){ 


Re 
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入 确认 父 级 目录 */ 

入 表单 值 ， 视 频 文件 特有 的 属性 */ 
S$director= $_ POST[director]: 

$marker=$_ POST[marker]; 

证 ”生成 insert 语 名 */ 

$a sqlstr = "insert into tb audio 


// 提 取 导 演 
/ 制 片 人 


(name,picture,sizes,grade,publisher,actor,director,marker,languages,type,style,froms,publishtime,bool,remark,property,address,u 


sername,issueDate) 


values('$names','$picture_path','$sizes','$grade','$publisher’,'$actor','$director','$marker','$language',' $types','$style','$from','$publ 
ishtime','$news',remark',' 管 理 员 ','$file_path','$_SESSION[admin]',".date("Y-m-d H:i:s").")"; 


} 
else if($ POST[action] 一 "v"){ 


/如 果 上 传 文件 为 音频 文件 
$actortype = $_POST[actortype]; /歌曲 类 型 
S$ci=$_POST[ci]; /作词 
$qu=$_ POST[qu]; /作曲 


上 证” 生成 insert 语 名 4/ 


$a_sqlstr = "insert into tb_video 
(name,picture,actor,ci,qu,actortype,type,style,publisher,froms,sizes,languages,publishTime,remark,property,address,u 
serName,issueDate) 
values('$names','$picture path',$actor,'$ci','S$qu','$actortype',' $types','$style','$publisher','$froms','$sizes','$language','$publishti 
me','$remark',' 管 理 员 ','$file_path''$_SESSION[admin],".date("Y-m-d H:i:s")."")"; 
jelsef 
echo "<script>alert( 错 误 ');window.close();</script>"; 
exit(); 


} 
人 # ”上传 图 片 和 文件 */ 
/闪闪 闪闪 于 闪闪 


$a rst = $conn->execute($a sqlstr); 
if(!($a_rst 一 false)) 
echo "<script>top.opener.location.reload(0;alert( 添 加 成 功 ");window .close();</script>"; 
else 
echo "<script>alert(' 添 加 失败 ');history.go(-1);</script>"; 
yc 


10.11.4 数据 删除 的 实现 过 程 


国 ”数据 删除 使 用 的 数据 表 : tb audio、tb_video 

视频 数据 删除 主要 是 根据 传递 的 文件 id 值 ， 将 数据 库 中 的 记录 删除 ， 同 时 ， 使 用 unlink 函数 删除 
服务 器 端的 真实 数据 。 程 序 代码 如 下 : 

例 程 16 ”代码 位 置 : 光盘 \TM\10\online\admin\del_video_chk.php 


<?php 
session_start(); // 开 启 session 支 持 
include "conn/conn.php"; // 载 入 数据 库 链 接 文 件 
include "inc/chec.php"; // 载 入 权限 判断 文件 
Sfile_path = "../upfiles/video/"; // 生 成 文件 路 径 
$s_sqlstr = "select * from tb_video where id =".$_GET[id]; /生成 SQL 语句 


$s rst = $conn->execute($s sqlstr); 
if(!($s_rst == false) { 
入 ”删除 相应 的 图 片 文件 和 音频 、 视 频 文件 */ 
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iunlink($file path.$s rst->fields[16]) and unlink($file path.$s rst->fields[2])){ 
让 ”生成 删除 语 旬 */ 
$d_sqlstr = "delete from tb_video where id =".$_GET[id]: 
入 执行 删除 语句 */ 
$d rst = $conn->execute($d sqlstr); 
if(!($d rst 一 false)){ 
echo "<script>alert(' 删 除 成 功 ');location='"main.php?action=video';</script>"; 
}else{ 
echo "<script>alert(' 删 除 失败 ');history.go(-1);</script>"; 
else 
echo "<script>alert(' 删 除 失败 ');history.go(-1);</script>"; 


10.12 ”管理 员 设 置 模块 设计 
10.12.1 管理 员 设 置 模块 概述 


管理 员 设 置 模块 主要 包括 管理 员 信息 添加 、 管 理 员 信息 删除 及 管理 员 信息 冻结 3 个 部 分 。 管 理 员 
可 以 通过 后 台 管 理 功能 导航 进入 管理 员 设 置 页 面 (member.php ) 。 在 管理 员 设置 页 面 中 ， 管 理 员 可 以 
进行 管理 员 信息 的 添加 操作 , 或 进行 会 员 信息 的 冻结 或 删除 等 操作 。 管 理 员 设置 用 例 图 如 图 10.35 所 示 。 


/ 


pe ea， 


i 删除 管理 员 


图 10.35 管理 员 管 理 用 例 图 
10.12.2 管理 员 设 置 模块 技术 分 析 


管理 员 可 以 单 击 管理 员 设 置 页 面 的 “冻结 ”或 “解冻 ”按钮 ， 对 管理 员 信息 进行 冻结 或 解冻 的 操 
作 。 当 管理 员 登 录 时 ， 首 先 查看 数据 库 中 的 whether 字段 ， 如 果 为 1， 则 说 明 该 用 户 处 于 激活 状态 ， 否 
者 ， 将 显示 提示 窗口 ， 告 诉 该 用 户 ， 此 账号 已 被 冻结 等 提示 信息 。 

对 管理 员 信息 的 冻结 或 解冻 操作 主要 是 根据 传递 的 管理 员 的 id， 将 数据 库 中 的 whether 字段 更 新 。 
程序 代码 如 下 : 

例 程 17 ”代码 位 置 ， 光盘 \TM\10\online\admin\m freeze_chk.php 


<?php 
session_start(); // 开 启 session 支 持 


Se 


第 10 章 online 影视 365 网 (Apache+PHP+ADODB+phpMyAdmin+MySQL 5.0 实现 ) 


include "conn/conn.php": /引入 数据 库 链 接 文件 
include "inc/chec.php"; /引入 权限 检查 文件 
证 ”根据 whether 值 ， 进 行 取 反 操作 */ 

if($_POST[whether] = "1") 


$wt= "0"; 
else if($ POST[whether] == "0") 
Swt= "1"; 
elsef 
echo "<script>alert(' 非 法 操作 !):history.go(-1);</script>"; 
exit(); 


} 
上 证” 根据 管理 员 id 和 赋值 后 的 Swt， 生 成 update 语 句 */ 
$o_sqlstr = "update tb_manager set whether = ".$wt." where id = ".$_POSTI[id]; 
证 ”执行 update 语 名 */ 
$o_rst = $conn->execute($0_sqlstr); 
if(!($o_rst =— false)){ 
echo "<script>alert(' 操 作成 功 ');location='main.php?action=manager';</script>"; 
} 
> 
该 方法 实现 很 简单 ， 但 却 十 分 实用 ， 在 使 用 会 员 制 的 网 站 上 ， 在 可 以 发 帖 、 回 复 的 论坛 里 ， 都 可 
以 使 用 这 个 方法 来 管理 。 


10.12.3 ”管理 员 添 加 的 实现 过 程 


国 管理 员 添加 使 用 的 数据 表 : tb_manager 

管理 员 可 以 通过 管理 员 设 置 页 面 打 开 管 理 员 信息 添加 页 面 (addmanagerphp) 。 在 管理 员 信息 添加 
页 面 中 ， 管 理 员 可 以 填写 表单 并 将 表单 提交 到 处 理 页 进行 数据 处 理 ， 以 完成 管理 员 信息 添加 的 操作 。 
管理 员 添加 页 面 的 运行 结果 如 图 10.36 所 示 。 


营 理 这 加 : |eeeeeee 


高 玛 确认 : |eeeeeee 


| 
真实 姓名 : [pc 
洁面][ 带 可 |] 


10.36 ”管理 员 添加 页 面 的 运行 结果 
管理 员 添加 页 面 涉及 到 的 HTML 表单 元 素 如 表 10.5 所 示 。 
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表 10.5 ”管理 员 添加 页 面 涉及 到 的 HTML 表单 元 素 


名 称 类 型 重要 属性 含 义 
list form method="post" action="addmanager_chk.php” 表单 
names text id="names" size="30" 管理 员 名 称 
_password | password id="password" size="30" 密码 
password2 password id="password2" size="30" 密码 确认 
<option value=" 视 频 目 录 管 理 员 " selected> 视 频 目 录 管 理 员 </option> 
<option value=" 音 频 目 录 管 理 员 "> 音频 目录 管理 员 </option> 
<option value=" 视 频数 据 管理 员 "> 视 频数 据 管 理 员 </option> 2 
grade select . J 管理 权限 
<option value=" 音 频数 据 管 理 员 "> 音 频数 据 管理 员 </option> 
<option value=" 会 员 数 据 管理 员 "> 会 员 数 据 管 理 员 </option> 
<option value=" 会 员 等 级 管理 员 "> 会 员 等 级 管理 员 </option> 
realname text id="realname" size="30" 真实 姓名 
Submit button class="submit" onClick="check():" “添加 ”按钮 
Submit2 button value=" 返 ” 回 " class="submit" onClick="javascript:top.window.close()" “返回 ”按钮 


管理 员 信 息 添加 的 数据 处 理 主要 是 根据 提交 的 表单 数据 ， 在 数据 库 中 添加 对 应 的 记录 ， 首 先 判断 


输入 姓名 是 否 存 在 ,如果 存在 , 显示 提示 语 ， 并 返回 到 上 一 步 。 如 果 不 存在 这 种 错误 ， 


添加 新 管理 员 。 程 序 代 码 如 下 : 
例 程 18 ”代码 位 置 ， 光盘 \TM\10\online\admin\addmanager.php 
<?php 
session_start(); 


include "conn/conn.php"; 
include "inc/chec.php"; 


生成 insert 语句 ， 


// 开 启 session 支 持 
// 载 入 数据 库 链 接 文 件 
// 载 入 权限 检查 文件 


$a_sql="select * from tb_manager where name='".$_POST[names]."":// 检 查 是 否 有 重 名 


$a_rst = $conn->execute($a_sql); 


履 ”如 果 管 理 员 昵 称 存在 ， 弹 出 提示 框 ， 并 返回 到 上 一 步 。*/ 


if(!$a rst->EOF) 


echo "<script>alert(' 该 名 称 的 管理 员 已 经 存在 ， 请 更 换 名 称 ');history.go(-1);</script>"; 


elsef 
证” 生成 insert 语 名 */ 


$a_sqlstr="insert into tb_manager 


values(",".$ POST[names].",".$ POST[password].",".$ POST[grade].",".$ POST[realname].",".date("Y-m-d").",1")"; 


此 ”执行 insert 语 名 */ 

$a_rstl = $conn->execute($a_sqlstr); 
全 如果 管理 员 添加 成 功 */ 

if(!($a rstl == false)){ 


<script> 
上 # 刷新 父 窗口 ， 弹 出 提示 框 ， 最 后 删除 当前 窗口 */ 
top.opener.location.reload(); 
alert(" 管 理 员 添加 成 功 "); 
top.window..close(); 
</script> 
<?php 


}: 
Sa 
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else 
echo "<script>alert(' 添 加 失败 ".$Sa_sqlstr."):history.go(-1);</script>"; 


10.12.4 ”管理 员 删 除 的 实现 过 程 


国 ”管理 员 删 除 使 用 的 数据 表 : tb_manager 
管理 员 信息 删除 主要 是 根据 传递 的 管理 员 的 id， 将 数据 库 中 对 应 的 数据 删除 。 程 序 代码 如 下 : 


例 程 19 ”代码 位 置 ， 光盘 \TM\10\online\admin\ del_mfreeze_chk.php 


<?php 

session_start(); /开启 session 支 持 

include "conn/conn.php"; // 载 入 数据 库 链 接 文件 

include "inc/chec.php"; // 载 入 权限 检查 文件 

$d_sqlstr = "delete from tb_manager where id=".$_GET[id]; /生成 delete 语 句 

if(!($d_rst = $conn->execute($d_sqlstr)) 一 false) // 判 断 删除 是 否 成 功 
echo "<script>alert(' 删 除 成 功 );location='main .php?action=manager:</script>"; 

else 


echo "<script>alert(' 删 除 失 败 ):history.go(-1):;</script>"; 


10.13 ”开发 技巧 与 难点 分 析 


在 本 系统 中 ， 多 个 地 方 使 用 了 无 边框 窗口 和 刷新 父 级 窗口 的 技术 。 下 面 来 学 习 一 下 有 关 这 两 方面 
的 知识 要 点 。 


10.13.1 无 边框 窗口 
平时 看 到 的 浏览 器 窗口 都 是 有 边框 的 ， 如 果 偶 尔 有 一 个 无 边框 的 窗口 弹出 ， 那 么 将 会 更 加 引信 注 
目 。 实 现 无 边框 窗口 使 用 的 是 JavaScript 脚本 中 的 open 方法 ，open 方法 的 常用 格式 如 下 : 
window.open(url,name,features,replace); 
open 方法 中 的 参数 解释 如 表 10.6 所 示 。 
表 10.6 open 方法 的 参数 说 明 


属 性 值 说 有明 

ul | 在 弹出 窗口 中 要 打开 的 地 址 

name, 要 打开 窗口 的 名 字 。 在 使 用 target 属 性 时 会 用 到 ， 可 以 为 空 

features 列举 的 窗口 特征 。 如 果 不 写 任何 参数 ， 那 么 默认 的 参数 多 数 情况 下 是 关闭 的 
Teplace -个 boolean 值 ， 指 出 是 否 url 替 换 当 前 内 容 。 该 参数 可 以 省 略 不 写 


01. 


PHP 项 目 开发 全 程 实录 


下 面 应 用 window 对 象 的 open 方法 打开 一 个 指定 大 小 的 窗口 。 代 码 如 下 : 


<script language="javascript"> 
wopen = open("list.php","query","height=500,width=665,scrollbars=no,toolbar=yes,location=yes"); 
</script> 


运行 结果 如 图 10.37 所 示 。 


加 
图 10.37 使 用 open 方法 弹出 窗口 
除了 上 面 实例 中 给 出 的 几 个 窗口 特征 ， 表 10.7 还 列 出 了 其 他 几 个 常用 的 特征 参数 及 说 明 。 
表 10.7 浏览 器 窗口 的 外 观 样式 


新 窗口 的 左 坐 标 


新 窗口 的 上 坐标 ， 配 合 lef 可 以 定位 一 个 窗口 的 弹出 位 置 
resizable 是 否 可 以 通过 拖 搜 来 调整 新 窗口 的 大 小 ， 默 认为 no 
在 新 窗口 中 是 否 显示 状态 栏 ， 默 认为 no 


全 注意 : 窗口 特征 是 用 等 号 贼 值 、 运 号 分 割 的 ， 在 运 号 或 等 号 前 后 不 要 加 上 空格 ， 因 为 在 有 些 浏览 器 
中 会 显示 错误 。 


10.13.2 ”刷新 父 级 窗口 和 关闭 子 窗口 


在 打开 的 子 窗口 进行 一 系列 的 操作 ， 如 添加 、 删 除数 据 后 ， 就 要 对 当前 窗口 进行 关闭 ， 最 后 返回 
父 级 窗口 中 ， 但 父 级 窗口 中 的 数据 可 能 仍然 是 没有 添加 或 删除 之 前 的 记录 数 ， 这 时 ， 就 可 以 调用 
JavaScript 脚本 , 对 父 窗口 进行 刷新 了 。 这 种 对 父 级 窗口 的 刷新 只 有 对 弹出 窗口 才 有 效 , 使 用 时 要 注意 。 
该 脚本 的 使 用 格式 为 : 


top.opener.location.reload(); 
operner 属性 是 子 窗口 的 最 高 层 window 对 象 才 有 的 属性 ,配合 location 对 象 可 以 对 父 窗口 进行 刷新 
或 重 载 。location 对 象 的 两 个 常用 方法 有 href 方法 和 reload 方法 。href 方法 可 以 刷新 父 窗口 内 容 ， 使 用 
格式 如 下 : 


Sm 
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top.opener.location.href="operation.php"; 
关闭 子 窗口 使 用 如 下 代码 即 可 : 
window.close(); 
不 过 这 里 要 注意 的 是 : close() 方 法 在 关闭 子 窗口 时 ， 不 弹出 提示 就 直接 关 掉 浏览 器 了 ,但 对 于 父 级 
窗口 ， 则 弹出 提示 框 ， 经 确认 后 才 可 以 关闭 浏览 器 。 


10.14 ” ADODB 连接 数据 库 技术 专题 


PHP 为 各 种 版 本 的 数据 库 定 义 了 庞大 的 函数 群 来 支持 ， 而 且 支 持 的 很 完整 ， 那 为 什么 本 系统 要 使 
用 ADODB 来 对 数据 库 进 行 操作 呢 ? 原因 在 于 ADODB 的 优势 : 一 次 编写 ， 不 需 修 改 。 也 就 是 说 ， 当 
系统 使 用 的 数据 库 需 要 更 换 时 ， 只 要 更 新 数据 库 、 数 据 表 即 可 ， 不 需要 再 重新 编写 源码 了 ， 这 为 后 期 
维护 节约 了 一 大 笔 开 销 ， 而 且 不 需要 长 时 间 关 闭 网 站 ， 这 是 PHP 函数 所 无 法 比拟 的 。 本 章 的 技术 专题 
就 来 着 重 学 习 一 下 ADODB 技术 。 


10.14.1 ADODB 简介 


由 於 PHP 存 取 函数 没有 标准 化 ， 不 同 数据 库 间 的 函数 名 称 、 参 数 差异 很 大 ， 在 更 换 数 据 库 时 ， 会 
带 来 大 量 的 代码 修复 工作 。 这 时 ， 就 需要 一 组 函数 库 来 隐藏 不 同 资料 库 函 数 界面 间 的 差异 ， 让 开发 者 
可 以 很 简单 地 去 切换 资料 库 , 这 就 是 ADODB。ADODB 目前 支持 MySQL、Oracle、Microsoft SQL Server、 
Sybase、PostgreSQL、Foxpro、Access、ADO 和 ODBC 等 大 多 数 知名 的 、 不 知名 的 数据 库 类 型 。 


10.14.2 ADODB 的 安装 

要 使 用 ADODB 来 操作 数据 库 ， 首 先 就 要 获取 和 安装 ADODB。 读 者 只 要 到 网 上 下 载 ADODB 包 ， 
解压 到 Web 服务 器 目录 下 即 可 。 
全 注意 : 要 使 用 ADODB， 使 用 的 PHP 必须 是 4.01 以 上 的 版 本 。 


10.14.3 ADODB 常用 函数 及 说 明 


在 10.4.2 节 中 已 经 介绍 过 了 使 用 ADODB 的 一 般 步骤 ， 在 实际 使 用 中 ， 需 要 根据 情况 进行 不 同 的 
处 理 ， 这 时 就 需要 对 步骤 及 功能 进行 扩展 ， 下 面 就 来 介绍 几 种 经 常会 用 到 的 函数 。 

1. PConnect($host,$user,$password, $database) 

$host: 数据 库 服 务 器 地 址 。 

Suser: 数据 库 用 户 名 。 

S$password: 数据 库 密码 。 
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$database: 连接 的 数据 库 。 
如 果 连 接 成 功 回 传 true， 失 败 则 回 传 false。 
2. SelectLimit($sql,$numrows=-1,$offset=-1) 
$sql: 执行 的 sql 语句 。 
S$numrows: 显示 的 记录 条 数 。 
S$offset: 从 第 几 条 记录 开始 计算 。 
这 个 函数 和 MySQL 里 的 limit 子 句 相似 ， 但 要 注意 ，limit 后 面 的 两 个 参数 的 顺序 是 〈limit 
offset,numrows) ， 这 个 函数 是 完全 相反 的 。 
3. ErrorMsg() 
回 传 错误 信息 。 当 execute0 函 数 出 现 错误 时 ， 使 用 ErrorMsg() 函 数 可 以 查看 最 后 出 错 的 相关 信息 。 
使 用 方法 如 下 : 


加 


<] 


S$recordset = $conn->Execute("select * from tb audio") 

if(!$recordset) // 判 断 execute() 函 数 执行 中 是 否 有 错误 
echo $conn->ErrorMsg(); 

elsef 


即使 没有 出 现 错误 ，ErrorMsg() 也 会 回 传 最 后 的 状态 值 ， 这 种 情况 下 一 般 不 需要 输出 。 
4. RecordCount() 
回 传 结 果 集 里 的 记录 数 。 使 用 方法 如 下 : 


$sql = 'select * from tb account'; 


S$rs = $conn->Execute($sql); /执行 SQL 语句 
echo $rs->RecordCount(); /输出 查询 结果 数 


5. FieldCount( ) 

回 传 结果 集 里 的 字段 数 。 使 用 方法 同上 。 

MoveNext( )、Move( )、MoveFirst( )、MoveLast( ) 

MoveNext(0: 移动 指针 到 一 下 条 记录 。 

Move($to): 移动 指针 到 指定 的 列 (Sto)。 这 里 使 用 的 是 绝对 定位 ， 如 Sto 是 10， 就 移动 到 结果 
集中 的 第 10 条 记录 ， 如 果 $to 大 于 记录 总 数 ， 指 针 将 移动 到 最 后 。 注 意 : 部 分 数据 库 不 支持 
想 后 移动 指针 。 

MoveFirst( ): 实际 上 就 是 Move(0)， 指 针 移动 到 结果 集 头 部 ， 部 分 数据 库 不 支持 该 函数 。 
MoveLast( ): 指针 移动 到 结果 集 的 尾部 ， 也 可 以 表示 为 Move($recordCount() 一 1)， 部 分 数据 
库 不 支持 此 函数 。 

最 后 介绍 一 个 ADODB 中 的 常量 。 


SS 


| 


四 加 
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7. $ADODB_FETCH_MODE 

该 常量 决定 了 结果 集 以 哪 种 方式 将 数据 回 传 。 在 有 些 数 据 库 中 ， 使 用 $recordset->fields[] 仅 支持 字 
段 编号 为 索引 ， 即 0、1、2 等 等 ， 不 支持 字段 名 (如 id，user) 做 索引 ， 这 时 ， 可 以 使 用 该 常量 进行 设 
置 ， 该 常量 的 值 有 : 


define('ADODB_FETCH_DEFAULT',0); // 系 统 默 认 值 
define('ADODB_FETCH_ NUM,,1); /以 字段 编号 为 索引 
define('ADODB_FETCH_ASSOC',2); // 以 字段 名 称 为 索引 
define('ADODB_FETCH_BOTH',3); // 同 时 用 时 编号 和 名 称 
这 时 上 面 的 步骤 可 以 改 为 : 


$conn = &ADONewConnection("mysq"); 
$conn->PConnect("db online"); 

$ADODB FETCH MODE=ADODB FETCH ASSOC:; 
S$recordset = $conn->Execute("select * from tb audio"); 


if(!$recordset) // 判 断 execute0) 函 数 执 行 中 是 否 有 错误 
echo $conn->ErrorMsg(); 
elsef 
while(l$recordset->EOF){ /如 果 没 有 错误 ， 则 配合 wihle 语 句 循环 输出 结果 
echo $recordset->fields[id]."<br>"; 
S$recordset->movenext(); 1/ 指针 下 移 


这 里 建议 将 SADODB_FIELDS_MODED 的 值 固定 为 ADODB_FETCH_NUM 及 ADODB _FETCH_ 
ASSOC， 不 建议 使 用 ADODB_FETCH_BOTH， 因 为 许多 驱动 程序 并 不 支持 该 常量 。 
ADODB 的 常用 函数 就 介绍 这 么 多 了 ， 如 果 读 者 感 兴趣 ， 可 以 下 载 ADODB 手册 来 学 习 更 多 内 容 。 


10.14.4 ”不同 数据 库 之 间 的 转换 


使 用 ADODB 的 优势 就 是 可 以 在 以 后 的 升级 中 ， 更 换 不 同 的 数据 库 而 不 用 大 量 的 改动 源 程序 。 但 
不 同 数据 库 之 间 ， 有 的 SQL 语句 或 语法 是 不 相同 的 ， 这 时 就 要 做 一 些小 幅 的 调整 。 
(1) 在 conn.php 文件 中 ， 更 改 连接 的 数据 库 类 型 和 参数 。 


$conn = &ADONewConnection('mysql); /建立 MySQL 连 接 
$conn->PConnect("localhost","root","root","db_online"); /连接 "db_online" 数 据 库 


如 使 用 SQL Server 时 ， 上 面 的 链接 语句 更 改 为 : 


$conn = &ADONewConnection(mssql); 
$conn->PConnect("localhost","sa","","db_online"); 


(2) 注意 包含 时 间 类 型 的 SQL 语句。 
不 同 的 数据 库 对 于 时 间 的 表示 法 是 不 同 的 ， 如 MySQL 使 用 时 间 类 型 时 ， 就 像 使 用 字符 类 型 一 样 ， 


本 
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放 到 单 引 号 里 就 可 以 了 ， 但 Access 则 需要 放 到 “#” 之 间 。ORACLE 虽然 也 是 使 用 单 引 号 ， 但 它 的 格 
式 为 “日 -月 -年 ”， 而 其 他 数据 库 大 多 都 是 “年 -月 -日 ”。 
(3) 尽量 使 用 通用 的 SQL 语句 。 
尽管 国际 标准 化 组 织 〈ISO) 在 1987 年 创建 了 SQL 的 一 个 标准 ， 但 在 各 种 SQL 之 间 仍 然 存在 差 
别 。 所 以 为 了 增加 通用 性 ， 最 好 了 解 一 下 数据 库 间 的 不 同 。 例 如 ，MySQL 中 的 limit 子 句 ， 在 oracle 
中 就 不 被 支持 。 


10.15 “本 章 总 结 


online 影视 365 网 实现 了 一 个 在 线 播放 平台 。 该 网 站 具备 一 个 影视 网 站 所 需要 的 所 有 的 基本 功能 ， 
包括 影视 文件 的 上 传 、 下 载 、 播 放 及 介绍 。 还 学 习 了 js 脚本 语言 的 一 些 实用 技巧 ， 最 后 ， 介 绍 了 本 章 
的 核心 内 容 : ADODB 连接 数据 库 技 术 。 和 希望 通过 本 章 的 学 习 ， 读 者 不 仅 可 以 建立 一 个 自己 的 影视 网 ， 
而 且 可 以 熟练 使 用 ADODB 来 连接 任意 一 个 数据 库 。 有 条 件 的 读者 可 以 试 着 将 本 系统 的 数据 库 改 为 
SQL Server 或 ORACLE， 来 增加 对 ADODB 的 了 解 及 熟练 程度 。 
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